JSON మరమ్మతు పరికరం

షురూ నుండి సురక్షితంగా, వేగంగా మరియు ఉచితంగా టұటిన లేదా తప్పు రూపంలో ఉన్న JSON ను ఆటోమేటిక్‌గా సరి చేసుకోండి మరియు పునరుద్ధరించుకోండి.

ఈ సాధనం ఆటోమేటెడ్ ఎర్రర్ కరెక్షన్ ద్వారా చేదిన లేదా చెల్లని JSON ను మరమ్మతు చేస్తుంది. ఇది ఎగుమతి చేసిన డేటా, లాగ్‌లు లేదా చేతితో సవరించిన ఫైళ్లలో కనిపించే అత్యధిక సాధారణ సింట్యాక్స్ సమస్యలపై దృష్టి సారిస్తుంది—అంటే కోట్స్ లేకపోవడం, తప్పు కామాలు, లేదా సరిపోని బ్రాకెట్ల వంటి సమస్యలు—and సరైన, పార్సబుల్ JSON ను ఉత్పత్తి చేస్తుంది.

మీ JSON ను కింద మళ్లీ గుర్తించండి

JSON రిపేర్ ఎలా పనిచేస్తుంది

ఈ సాధనం మీ ఇన్‌పుట్‌లో సాంప్రదాయ JSON సింటాక్స్ సమస్యలను పరిశీలించి, లక్ష్యపూర్వకమైన సవరణలను వర్తింపజేస్తుంది, సాధ్యమైతే చెల్లుబాటు అయ్యే JSONని ఉత్పత్తి చేస్తుంది.

  1. ఇన్‌పుట్‌ను విశ్లేషించి, సాధారణ نحو లోపాలను గుర్తించి పరిష్కరిస్తుంది, వాటిలో చట్టబద్ధం కాని అక్షరాలు, తప్పుగా ఉంచిన తెరుచుకున్న కోట్స్, అప్రామాణిక స్ట్రింగ్ ఉద్దరణలు ఉన్నాయి.
  2. హగ్గి తప్పులు సరిచేయడానికి ఉపయోగిస్తారు—పేజీలేని అడ్డంకులు జోడించడం, లాంటివంటివి తొలగించడం, లేదా కోట్స్, కామాలు మరియు బ్రాకెట్లను సరిదిద్దడం వంటి సాధారణ పొరపాట్లను మార్చుతుంది.
  3. తిద్దుబాటు చేయబడిన JSON‌ను ఉత్పత్తి చేస్తుంది. చాలాసార్లు, ఫలితం చెల్లింపు లేదా తక్షణమే ఉపయోగానికి సిద్ధంగా ఉంటుంది.
  4. గటమైన నిర్మాణాన్ని స్వయంచాలకంగా మరమ్మతు చేయలేనప్పుడు, మీరు మీ ఇన్‌పుట్‌ను సరిచేసుకోవడానికి స్పష్టమైన లోపాన్ని చూపిస్తారు.

ప్రచలిత JSON లోపాలు మరియు వాటిని ఎలా సరిచేయాలి

ఈ టూల్ సరిచూడగల సాధారణ JSON లోపాలు మరియు వాటి కోసం ఉదాహరణలు ఇవి:

ఉబికాయించని కీల్లు

కీలు ద్విగుణపుటరులలో ఉండాలి.

Before:
{ name: "బాబ్" }
After:
{ "name": "బాబ్" }

విపరీతము: ఎటువంటి ఉల్లేఖనాలేని ఆబ్జెక్ట్ కీల చుట్టూ రెండు గుండ్లు పేర్కొన్నప్పుడు జోడించబడుతుంది.

ఒకే ముద్రణల సూచనలు ఉపయోగించబడ్డాయి

JSON స్ట్రింగుల కోసం డబుల్ కొటేషన్స్‌ను మాత్రమే అంగీకరిస్తుంది.

Before:
{ 'పాత్ర': 'అడ్మిన్' }
After:
{ "role": "నిర్వాహకుడు" }

సరి చేసారు: అన్ని స్ట్రింగ్‌లలో సింగిల్ కోట్స్‌ను డబుల్ కోట్స్‌తో మార్చబడింది.

శేష కామాలు

చివరి అంశం తర్వాత కామా అనుమతించబడదు.

Before:
{ "a": 1, "b": 2, }
After:
{ "a": 1, "b": 2 }

పరిష్కారం: ఏ విభజక రహిత కామాలను (ట్రైలింగ్ కామాలను) తీసివేస్తుంది.

పరస్పరం సరిపోలని లేదా మూసివేయని కోటేషన్లు

అన్ని బ్రాకెట్లు మరియు బ్రేసులు సరిగ్గా మూసివేయాలి.

Before:
[1, 2, 3
After:
[1, 2, 3]

శోధన: మిస్సింగ్ ముగింపు బ్రాకెట్లు లేదా బ్రేసెస్ జోడించండి.

లేమి ఉన్న లేదా అదనపు కామాలు

అర్రే మరియు ఆబ్జెక్ట్ అంశాలు ఒక్క కామాతో విభజించాలి.

Before:
{ "a": 1 "b": 2 }
After:
{ "a": 1, "b": 2 }

సరిచూడండి: ప్రతి చోట commas లేమి ఉన్నట్లయితే చేర్పిస్తుంది, లేదా ప్రతిరూపాలను తొలగిస్తుంది.

కామెంట్లు ఉన్న పంక్తులు

స్టాండర్డ్ JSON వ్యాఖ్యలను అనుమతించదు (ఉదాహరణకు // లేదా /* ... */).

Before:
{ "id": 1, // వినియోగదారు ID
 "active": true }
After:
{ "id": 1, "active": true }

పరిష్కారం: ఇన్‌పుట్‌లోని వ్యాఖ్యాన పంక్తులను తీసివేస్తుంది.

చెల్లని సంఖ్య ఫార్మాట్లు

కేవలం సాధారణ దశాంశ సంఖ్యలు మాత్రమే válida (NaN, ఇన్ఫినిటీ లేదా హెక్సాడెసిమల్‌లు లేవు).

Before:
{ "val": సంఖ్య కాదు }
After:
{ "val": null }

సరైనది: చెల్లనివంటి సంఖ్యలను null తో మార్చండి.

అనూహ్య నియంత్రణ అక్షరాలు

స్ట్రింగుల్లో కొత్త వరుసల వంటి అక్షరాలు ఎస్కేప్ చేయాలి.

Before:
{ "msg": "లైన్1
లైన్2" }
After:
{ "msg": "లైన్1\nలైన్2" }

పరిష్కారం: కంట్రోల్ అక్షరాలను సరైన విధంగా ఎస్కేప్ చేస్తుంది.

ఆబ్జెక్టులో నకిలీ కీలు

ఒకే ఆబ్జెక్టులో డుప్లికేట్ కీలు స్పష్టతను తగ్గిస్తాయి.

Before:
{ "name": "A", "name": "B" }
After:
{ "name": "బి" }

సరిచేయండి: ఎన్ని డూప్లికేట్ కీలు ఉన్నా చివరి విలువనే మాత్రమే ఉంచుతుంది.

తప్పు வடివార్చిన అర్రేలు

సూచికలు కోట్స్ మరియు అంశాల మధ్య అక్షరాలు తప్పనిసరి.

Before:
[ 1 2 3 ]
After:
[ 1, 2, 3 ]

పరిష్కారం: శ్రేణి భాగాల మధ్య కోల్పోయిన కామాలు చేర్చబడినవి.

ఖాళీ ఇన్‌పుట్ లేదా అంతా స్పేసెస్

JSON ఖాళీగా ఉండకూడదు.

Before:
After:
నల్

పరిష్కారం: ఖాళీ ఇన్‌పుట్‌కోసం నల్ (null) అతిరేక లేకుండా తిరిగి ఇచ్చాలి.

ఉదాహరణ: రద్దయిన JSON నుండి చెల్లుబాటు అయ్యే మరమ్మత్తు వరకు

తప్పు ఆకారంలో ఉన్న JSON ఇన్‌పుట్
{ user: 'అలిస్', id: 42, roles: [అడ్మిన్, 'ఎడిటర్',] // అదనపు అర్థాలు
 active: true }
నికార గుర్తించిన JSON అవుట్పుట్
{
  "user": "అలిస్",
  "id": 42,
  "roles": [
    "నిర్వాహకుడు",
    "సంపాదకుడు"
  ],
  "active": true
}

ఈ JSON రిపేర్ టూల్‌ను ఎలా ఉపయోగించాలి

  1. క్రింద ఉన్న ఎడిటర్‌లో మీ బంభగొట్టబడిన JSON‌ని పేస్ట్ చేయండి లేదా టైప్ చేయండి.
  2. సాధారణ వ్యాకరణ లోపాలను స్వయంచాలకంగా గుర్తించి సరిచేయడం కోసం 'మరమ్మత్తు'పై నొక్కండి.
  3. మరమ్మతులు చేసిన ఆవుట్పుట్‌ను సమీక్షించి, మీ సరిచేసిన JSON ను కాపీ చేయండి.

సంక్లిష్టమైన లేదా తీవ్రంగా దెబ్బతిన్న ఇన్‌పుట్ల కోసం, critical డేటా కోసం ఉపయోగించే ముందు మరమ్మతు చేసిన JSONని ఎప్పుడూ పరీక్షించండి—మాన్యువల్ సవరణలు అవసరం కావచ్చు.

JSON మరమ్మతు కోసం కోడ్ ఉదాహరణలు

వివిధ ప్రోగ్రామింగ్ భాషల్లో JSONని ఎలా మరమ్మతు చేసుకోవాలో చూడండి.

JavaScript (Node.js) with jsonrepair
Install: npm install jsonrepair
const { jsonrepair } = require('jsonrepair');
const broken = '{ name: "Bob", age: 42, }';
const fixed = jsonrepair(broken);
console.log(fixed); // Now valid JSON!
JavaScript (Node.js) simple fix (not for production)
Install: Standard library
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);
}
Python with dirtyjson
Install: pip install dirtyjson
import dirtyjson
broken = "{ name: 'Bob', age: 42 }"
obj = dirtyjson.loads(broken)
print(obj)
Python with demjson3
Install: pip install demjson3
import demjson3
broken = "{ name: 'Bob', age: 42 }"
obj = demjson3.decode(broken)
print(obj)
Go (using otto for JS-like object parsing)
Install: go get github.com/robertkrimen/otto
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)
  }
}
Java with org.json (manual fix for single quotes)
Install: org.json:json
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);
  }
}
C# with Newtonsoft.Json (try-catch, manual fix)
Install: Newtonsoft.Json
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 (manual fix for single quotes/unquoted keys)
Install: Standard library
<?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);
Ruby with json-repair (via gem or shell call)
Install: gem install json-repair or use npx jsonrepair
# Using system call to npx jsonrepair
require 'open3'
broken = "{ name: 'Bob', age: 42 }"
fixed, _ = Open3.capture2("echo #{broken.inspect} | npx jsonrepair")
puts fixed
Bash (npx jsonrepair CLI)
Install: npm install -g jsonrepair
echo "{ name: 'Bob', age: 42 }" | npx jsonrepair
Rust (suggest manual pre-processing)
Install: Standard libraries
// Rust does not have a json repair crate yet. Pre-process string with regex to fix simple cases, then use serde_json.
Kotlin (manual fix, like Java)
Install: org.json: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)
}
TypeScript (Node.js) with jsonrepair
Install: npm install jsonrepair
import { jsonrepair } from 'jsonrepair';
const broken = '{ name: "Bob", age: 42 }';
const fixed = jsonrepair(broken);
console.log(fixed);
Dart (manual string fixes)
Install: Standard library
var broken = "{ name: 'Bob', age: 42 }";
var fixed = broken.replaceAll("'", '"').replaceAllMapped(
  RegExp(r'([a-zA-Z0-9_]+):'),
  (m) => '"${m[ 1 ]}":',
);
print(fixed);
Elixir (manual fix with Regex)
Install: Standard library
broken = "{ name: 'Bob', age: 42 }"
fixed = Regex.replace(~r/'/, broken, """)
fixed = Regex.replace(~r/(\w+):/, fixed, ""\\1":")
IO.puts(fixed)