Nástroj pro opravu JSON
Automaticky opravte a obnovte poškozený nebo neplatný JSON – bezpečně, rychle a zdarma.
Tento nástroj opravuje poškozený nebo neplatný JSON pomocí automatické korekce chyb. Zaměřuje se na nejčastější problémy se syntaxí, které se vyskytují v exportovaných datech, protokolech nebo ručně upravovaných souborech — jako jsou chybějící uvozovky, přebytečné čárky nebo nesouhlasné závorky — a vytváří platný JSON, který je možné bez problémů zpracovat.
Opravte svůj JSON níže
Jak funguje oprava JSON
Nástroj kontroluje váš vstup na běžné chyby v syntaxi JSON a aplikuje cílené opravy, aby byl výstup, pokud možno, platným JSONem.
- Analyzuje vstup a lokalizuje běžné syntaktické chyby, včetně nelegálních znaků, nesprávně umístěných závorek a chybných uvozovek řetězců.
- Aplikuje opravy běžných chyb – jako je doplnění chybějících uvozovek, odstranění závěrečných čárek nebo oprava závorek.
- Vytiskne opravený JSON. Ve většině případů je výsledek ihned připraven k parsování nebo okamžitému použití.
- Pokud nelze strukturu automaticky opravit, zobrazí se jasná chyba, abyste mohli upravit svůj vstup.
Běžné chyby v JSON a jak je opravit
Zde jsou typické chyby v JSON, které tento nástroj dokáže opravit, s příklady pro každou z nich:
Nepoužívané klíče bez uvozovek
Klíče musí být v uvozovkách.
{ jméno: "Bob" }
{ "name": "Bob" }
Oprava: Přidává uvozovky kolem všech nepřevzatých klíčů objektů.
Použity jednoduché uvozovky
JSON akceptuje pouze dvojité uvozovky pro řetězce.
{ 'role': 'správce' }
{ "role": "administrátor" }
Oprava: Nahrazuje jednoduché uvozovky za dvojité uvozovky ve všech řetězcích.
Končící čárky
Po poslední položce není povolena čárka.
{ "a": 1, "b": 2, }
{ "a": 1, "b": 2 }
Oprava: Odstraňuje všechny koncové čárky.
Nesoulad nebo Neuzavřené závorky
Všechny závorky a složené závorky musí být správně uzavřeny.
[1, 2, 3
[1, 2, 3]
Oprava: Přidání chybějících závěrečných závorek nebo složených závorek.
Chybějící nebo nadbytečné čárky
Položky pole a objektu musí být odděleny jedinou čárkou.
{ "a": 1 "b": 2 }
{ "a": 1, "b": 2 }
Oprava: Vkládá chybějící čárky nebo odstraňuje duplicity.
Přítomnost komentovaných řádků
Standardní JSON neumožňuje komentáře (jako // nebo /* ... */).
{ "id": 1, // ID uživatele "active": true }
{ "id": 1, "aktivní": true }
Oprava: Odstraňuje řádky s komentáři ze vstupu.
Neplatné formáty čísel
Platná jsou pouze běžná desetinná čísla (žádné NaN, nekonečno ani šestnáctkové hodnoty).
{ "val": NaN }
{ "val": null }
Oprava: Nahrazuje neplatná čísla hodnotou null.
Neuniklé řídicí znaky
Znaky jako nové řádky v řetězcích musí být escapovány.
{ "msg": "Řádek1 Řádek2" }
{ "msg": "Řádek1\nŘádek2" }
Oprava: Správné ošetření ovládacích znaků.
Duplicitní klíče v objektu
Duplicitní klíče ve stejném objektu způsobují nejasnosti.
{ "name": "A", "name": "B" }
{ "name": "B" }
Oprava: Zachovává pouze poslední hodnotu pro každý duplicitní klíč.
Chybně vytvořené pole
Pole musí mít závorky a čárky mezi položkami.
[ 1 2 3 ]
[ 1, 2, 3 ]
Oprava: Přidány chybějící čárky mezi prvky pole.
Prázdný vstup nebo pouze bílé znaky
JSON nesmí být prázdný.
null
Oprava: Vrací null pro prázdný vstup.
Příklad: Od poškozeného JSONu k platné opravě
{ user: 'alice', id: 42, roles: [admin, 'editor',] // extra comma active: true }Opravený JSON výstup
{ "user": "alice", "id": 42, "roles": [ "správce", "editor" ], "active": true }
Jak používat tento nástroj pro opravu JSON
- Vložte nebo napište svůj poškozený JSON do editoru níže.
- Klikněte na 'Opravit' pro automatickou detekci a odstranění běžných syntaktických chyb.
- Zkontrolujte opravený výstup a zkopírujte svůj opravený JSON.
Vždy si před použitím opraveného JSONu pro kritická data ověřte jeho správnost – u složitých nebo výrazně poškozených vstupů může být nutné ruční doladění.
Ukázky kódu pro opravu JSON
Zjistěte, jak opravit JSON v různých programovacích jazycích.
const { jsonrepair } = require('jsonrepair');
const broken = '{ name: "Bob", age: 42, }';
const fixed = jsonrepair(broken);
console.log(fixed); // Now valid JSON!
let broken = "{ name: 'Bob', age: 42 }";
broken = broken.replace(/(['"])?:([\s]*)([^\s,\{\}\[\]":']+)/g, '"$1$3":');
try {
let obj = JSON.parse(broken);
console.log(obj);
} catch (e) {
console.error('Still broken:', e.message);
}
import dirtyjson
broken = "{ name: 'Bob', age: 42 }"
obj = dirtyjson.loads(broken)
print(obj)
import demjson3
broken = "{ name: 'Bob', age: 42 }"
obj = demjson3.decode(broken)
print(obj)
package main
import (
"fmt"
"github.com/robertkrimen/otto"
)
func main() {
vm := otto.New()
broken := "{ name: 'Bob', age: 42 }"
value, err := vm.Run("(" + broken + ")")
if err != nil {
fmt.Println("Cannot repair:", err)
} else {
obj, _ := value.Export()
fmt.Println(obj)
}
}
import org.json.JSONObject;
public class Main {
public static void main(String[] args) {
String broken = "{'name': 'Bob', 'age': 42}".replace(''', '"');
JSONObject obj = new JSONObject(broken);
System.out.println(obj);
}
}
using System;
using Newtonsoft.Json;
class Program {
static void Main() {
var broken = "{ name: 'Bob', age: 42 }".Replace("'", "\"");
try {
var obj = JsonConvert.DeserializeObject(broken);
Console.WriteLine(obj);
} catch (Exception ex) {
Console.WriteLine("Broken JSON: " + ex.Message);
}
}
}
<?php
$broken = "{ name: 'Bob', age: 42 }";
$fixed = preg_replace("/'([^"]*)'/", '"$1"', $broken);
$fixed = preg_replace('/([a-zA-Z0-9_]+):/', '"$1":', $fixed);
$obj = json_decode($fixed);
var_dump($obj);
# Using system call to npx jsonrepair
require 'open3'
broken = "{ name: 'Bob', age: 42 }"
fixed, _ = Open3.capture2("echo #{broken.inspect} | npx jsonrepair")
puts fixed
echo "{ name: 'Bob', age: 42 }" | npx jsonrepair
// Rust does not have a json repair crate yet. Pre-process string with regex to fix simple cases, then use serde_json.
import org.json.JSONObject
fun main() {
var broken = "{ name: 'Bob', age: 42 }".replace("'", "\"")
broken = Regex("([a-zA-Z0-9_]+):").replace(broken, ""$1":")
val obj = JSONObject(broken)
println(obj)
}
import { jsonrepair } from 'jsonrepair';
const broken = '{ name: "Bob", age: 42 }';
const fixed = jsonrepair(broken);
console.log(fixed);
var broken = "{ name: 'Bob', age: 42 }";
var fixed = broken.replaceAll("'", '"').replaceAllMapped(
RegExp(r'([a-zA-Z0-9_]+):'),
(m) => '"${m[ 1 ]}":',
);
print(fixed);
broken = "{ name: 'Bob', age: 42 }"
fixed = Regex.replace(~r/'/, broken, """)
fixed = Regex.replace(~r/(\w+):/, fixed, ""\\1":")
IO.puts(fixed)