2012-01-11 16 views
10

में कनवर्ट करें मैं वेब सर्वर से .json फ़ाइल पढ़ने की कोशिश कर रहा हूं। JSON मैं सर्वर से प्राप्त कर रहा http://jsonlint.com/ पर अमान्य होने की सूचना दी है:अमान्य जेसन को वैध जेसन

Parse error on line 1: 
{ preOpen: "900",  
-----^ 
Expecting 'STRING', '}' 

मैं इसे कैसे परिवर्तित कर सकते हैं वैध करने के लिए:

{ 
    preOpen: "900", 
    preClose: "908", 
    mktOpen: "915", 
    mktClose: "1530", 
    corrOpen: "1540", 
    corrClose: "1600", 
    mktStatusCode: "3", 
    status: "MARKET OPEN", 
    time: "Jan 11, 2012 12:32:14", 
    data: [ 
     { 
      name: "S&P CNX NIFTY Pre Open", 
      lastPrice: "4,863.15", 
      change: "13.60", 
      pChange: "0.28", 
      imgFileName: "S&P_CNX_NIFTY_Pre_Open_open.png" 
     }, 
     { 
      name: "S&P CNX NIFTY", 
      lastPrice: "4,871.15", 
      change: "21.60", 
      pChange: "0.45", 
      imgFileName: "S&P_CNX_NIFTY_open.png" 
     }, 
     { 
      name: "CNX NIFTY JUNIOR", 
      lastPrice: "8,940.05", 
      change: "91.90", 
      pChange: "1.04", 
      imgFileName: "CNX_NIFTY_JUNIOR_open.png" 
     }, 
     { 
      name: "BANK NIFTY", 
      lastPrice: "8,816.15", 
      change: "81.10", 
      pChange: "0.93", 
      imgFileName: "BANK_NIFTY_open.png" 
     }, 
     { 
      name: "INDIA VIX", 
      lastPrice: "24.18", 
      change: "0.18", 
      pChange: "0.75", 
      imgFileName: "INDIA_VIX_open.png" 
     }, 
     { 
      name: "CNX 100", 
      lastPrice: "4,729.25", 
      change: "25.05", 
      pChange: "0.53", 
      imgFileName: "CNX_100_open.png" 
     }, 
     { 
      name: "S&P CNX DEFTY", 
      lastPrice: "3,265.00", 
      change: "41.70", 
      pChange: "1.29", 
      imgFileName: "S&P_CNX_DEFTY_open.png" 
     }, 
     { 
      name: "S&P CNX 500", 
      lastPrice: "3,811.75", 
      change: "26.40", 
      pChange: "0.70", 
      imgFileName: "S&P_CNX_500_open.png" 
     }, 
     { 
      name: "CNX MIDCAP", 
      lastPrice: "6,548.20", 
      change: "80.65", 
      pChange: "1.25", 
      imgFileName: "CNX_MIDCAP_open.png" 
     }, 
     { 
      name: "NIFTY MIDCAP 50", 
      lastPrice: "1,937.20", 
      change: "21.30", 
      pChange: "1.11", 
      imgFileName: "NIFTY_MIDCAP_50_open.png" 
     }, 
     { 
      name: "CNX INFRA", 
      lastPrice: "2,273.60", 
      change: "8.50", 
      pChange: "0.38", 
      imgFileName: "CNX_INFRA_open.png" 
     }, 
     { 
      name: "CNX REALTY", 
      lastPrice: "207.85", 
      change: "8.10", 
      pChange: "4.06", 
      imgFileName: "CNX_REALTY_open.png" 
     }, 
     { 
      name: "CNX ENERGY", 
      lastPrice: "7,300.55", 
      change: "37.10", 
      pChange: "0.51", 
      imgFileName: "CNX_ENERGY_open.png" 
     }, 
     { 
      name: "CNX FMCG", 
      lastPrice: "10,308.90", 
      change: "10.90", 
      pChange: "0.11", 
      imgFileName: "CNX_FMCG_open.png" 
     }, 
     { 
      name: "CNX MNC", 
      lastPrice: "4,660.35", 
      change: "30.40", 
      pChange: "0.66", 
      imgFileName: "CNX_MNC_open.png" 
     }, 
     { 
      name: "CNX PHARMA", 
      lastPrice: "4,743.15", 
      change: "-4.15", 
      pChange: "-0.09", 
      imgFileName: "CNX_PHARMA_open.png" 
     }, 
     { 
      name: "CNX PSE", 
      lastPrice: "2,753.90", 
      change: "14.60", 
      pChange: "0.53", 
      imgFileName: "CNX_PSE_open.png" 
     }, 
     { 
      name: "CNX PSU BANK", 
      lastPrice: "2,847.95", 
      change: "22.80", 
      pChange: "0.81", 
      imgFileName: "CNX_PSU_BANK_open.png" 
     }, 
     { 
      name: "CNX SERVICE", 
      lastPrice: "5,933.65", 
      change: "21.65", 
      pChange: "0.37", 
      imgFileName: "CNX_SERVICE_open.png" 
     }, 
     { 
      name: "CNX IT", 
      lastPrice: "6,300.35", 
      change: "-31.40", 
      pChange: "-0.50", 
      imgFileName: "CNX_IT_open.png" 
     }, 
     { 
      name: "CNX SMALLCAP", 
      lastPrice: "2,981.80", 
      change: "49.85", 
      pChange: "1.70", 
      imgFileName: "CNX_SMALLCAP_open.png" 
     }, 
     { 
      name: "CNX 200", 
      lastPrice: "2,432.05", 
      change: "14.35", 
      pChange: "0.59", 
      imgFileName: "CNX_200_open.png" 
     }, 
     { 
      name: "CNX AUTO", 
      lastPrice: "3,497.60", 
      change: "4.05", 
      pChange: "0.12", 
      imgFileName: "CNX_AUTO_open.png" 
     }, 
     { 
      name: "CNX MEDIA", 
      lastPrice: "1,147.30", 
      change: "23.35", 
      pChange: "2.08", 
      imgFileName: "CNX_MEDIA_open.png" 
     }, 
     { 
      name: "CNX METAL", 
      lastPrice: "2,746.95", 
      change: "60.60", 
      pChange: "2.26", 
      imgFileName: "CNX_METAL_open.png" 
     } 
    ] 
} 

इसकी निम्नलिखित परीक्षा परिणाम प्रदर्शित JSON का उपयोग कर इसे पार्स करने से पहले JSON ??

+0

चाबियाँ डबल कोट्स में होनी चाहिए - इसलिए प्रीऑपेन: "900" "preOpen" होना चाहिए: "900", और इसी तरह। यदि आपके पास जेसन स्रोत पर नियंत्रण नहीं है तो यह सुनिश्चित न करें कि इसे कैसे ठीक किया जाए। आप रेगेक्स का उपयोग कर सकते हैं - कोलन से पहले एक शब्द की तलाश करें और इसे डबल कोट्स में शामिल करें। –

उत्तर

7

सभी keys (preOpen, preClose, ...) तार होना चाहिए, इसलिए उन्हें चारों ओर डबल-कोट्स की आवश्यकता है।

{ 
    "preOpen": "900", 
    "preClose": "908", 
    ... 
} 

=== अद्यतन ===

आप में अमान्य JSON-स्ट्रिंग आप निम्नलिखित स्क्रिप्ट के साथ परिवर्तित कर सकते हैं:

$sInvalidJson = '{ 
    preOpen: "900", 
    preClose: "908" 
}'; 
$sValidJson = preg_replace("/(\n[\t ]*)([^\t ]+):/", "$1\"$2\":", $sInvalidJson); 

इसके अलावा इस example देखते हैं।

(यह स्क्रिप्ट केवल अमान्य JSON ऊपर वर्णित के साथ काम करता है, अन्यथा पैटर्न को बदलने की है।)

=== अद्यतन ===

$sInvalidJson = '{preOpen:"900",preClose:"908",mktOpen:"915",mktClose:"1530",corrOpen:"1540",corrClose:"1600",mktStatusCode:"3",status:"MARKET OPEN",time:"Jan 11, 2012 14:25:15",data:[{name:"S&P CNX NIFTY Pre Open",lastPrice:"4,863.15",change:"13.60",pChange:"0.28",imgFileName:"S&P_CNX_NIFTY_Pre_Open_open.png"},{name:"S&P CNX NIFTY",lastPrice:"4,847.85",change:"-1.70",pChange:"-0.04",imgFileName:"S&P_CNX_NIFTY_open.png"},{name:"CNX NIFTY JUNIOR",lastPrice:"8,917.00",change:"68.85",pChange:"0.78",imgFileName:"CNX_NIFTY_JUNIOR_open.png"},{name:"BANK NIFTY",lastPrice:"8,768.75",change:"33.70",pChange:"0.39",imgFileName:"BANK_NIFTY_open.png"},{name:"INDIA VIX",lastPrice:"24.61",change:"0.61",pChange:"2.54",imgFileName:"INDIA_VIX_open.png"},{name:"CNX 100",lastPrice:"4,707.85",change:"3.65",pChange:"0.08",imgFileName:"CNX_100_open.png"},{name:"S&P CNX DEFTY",lastPrice:"3,253.50",change:"30.20",pChange:"0.94",imgFileName:"S&P_CNX_DEFTY_open.png"},{name:"S&P CNX 500",lastPrice:"3,795.40",change:"10.05",pChange:"0.27",imgFileName:"S&P_CNX_500_open.png"},{name:"CNX MIDCAP",lastPrice:"6,524.90",change:"57.35",pChange:"0.89",imgFileName:"CNX_MIDCAP_open.png"},{name:"NIFTY MIDCAP 50",lastPrice:"1,926.55",change:"10.65",pChange:"0.56",imgFileName:"NIFTY_MIDCAP_50_open.png"},{name:"CNX INFRA",lastPrice:"2,262.05",change:"-3.05",pChange:"-0.13",imgFileName:"CNX_INFRA_open.png"},{name:"CNX REALTY",lastPrice:"207.70",change:"7.95",pChange:"3.98",imgFileName:"CNX_REALTY_open.png"},{name:"CNX ENERGY",lastPrice:"7,301.05",change:"37.60",pChange:"0.52",imgFileName:"CNX_ENERGY_open.png"},{name:"CNX FMCG",lastPrice:"10,235.35",change:"-62.65",pChange:"-0.61",imgFileName:"CNX_FMCG_open.png"},{name:"CNX MNC",lastPrice:"4,631.55",change:"1.60",pChange:"0.03",imgFileName:"CNX_MNC_open.png"},{name:"CNX PHARMA",lastPrice:"4,749.95",change:"2.65",pChange:"0.06",imgFileName:"CNX_PHARMA_open.png"},{name:"CNX PSE",lastPrice:"2,744.85",change:"5.55",pChange:"0.20",imgFileName:"CNX_PSE_open.png"},{name:"CNX PSU BANK",lastPrice:"2,841.10",change:"15.95",pChange:"0.56",imgFileName:"CNX_PSU_BANK_open.png"},{name:"CNX SERVICE",lastPrice:"5,900.60",change:"-11.40",pChange:"-0.19",imgFileName:"CNX_SERVICE_open.png"},{name:"CNX IT",lastPrice:"6,262.10",change:"-69.65",pChange:"-1.10",imgFileName:"CNX_IT_open.png"},{name:"CNX SMALLCAP",lastPrice:"2,963.90",change:"31.95",pChange:"1.09",imgFileName:"CNX_SMALLCAP_open.png"},{name:"CNX 200",lastPrice:"2,421.50",change:"3.80",pChange:"0.16",imgFileName:"CNX_200_open.png"},{name:"CNX AUTO",lastPrice:"3,484.30",change:"-9.25",pChange:"-0.26",imgFileName:"CNX_AUTO_open.png"},{name:"CNX MEDIA",lastPrice:"1,139.60",change:"15.65",pChange:"1.39",imgFileName:"CNX_MEDIA_open.png"},{name:"CNX METAL",lastPrice:"2,726.75",change:"40.40",pChange:"1.50",imgFileName:"CNX_METAL_open.png"}]}'; 
$sValidJson = preg_replace("/([{,])([a-zA-Z][^: ]+):/", "$1\"$2\":", $sInvalidJson); 

इसके अलावा इस updated example

+0

बहुत अच्छा जवाब। भाग के समय को छोड़कर बहुत अच्छा काम करता है: "11 जनवरी, 2012 12:32:14", जो खराब हो गया है। – DKSan

+0

@DKSan: thx, मैंने अपना जवाब अपडेट कर लिया है। – scessor

+0

मैं निम्नलिखित कोड का उपयोग बिना किसी सफलता के कर रहा हूं: '$ url = 'http: //abc/abc.json'; $ सत्र = curl_init ($ url); curl_setopt ($ सत्र, CURLOPT_USERAGENT, 'मोज़िला/5.0 (विंडोज़; यू; विंडोज एनटी 5.1; एन-यूएस; आरवी: 1.8.1.13) गेको/20080311 फ़ायरफ़ॉक्स/2.0.0.13'); curl_setopt ($ सत्र, CURLOPT_POST, सत्य); curl_setopt ($ सत्र, CURLOPT_HEADER, झूठा); curl_setopt ($ सत्र, CURLOPT_RETURNTRANSFER, सत्य); $ json = curl_exec ($ सत्र); echo $ json; गूंज "


"; $ sValidJson = preg_replace ("/ (\ n [\ t] *) ([^ \ t] +): /", "$ 1 \" $ 2 \ ":", $ json); echo $ sValidJson; 'मुझे वही आउटपुट मिल रहा है !!!! – Sandy505

2

मेरा मानना ​​है कि उचित JSON तारों को सभी प्रमुख नामों के चारों ओर डबल कोट्स की भी आवश्यकता है। जो आप दिखाते हैं वह एक वैध जावास्क्रिप्ट ऑब्जेक्ट है, लेकिन जब JSON में स्ट्रिंग किया जाता है तो सभी चाबियों के चारों ओर डबल कोट होना चाहिए।

+0

हाँ, 'JSON.stringify (eval ({preOpen: "900", ....} का उपयोग करके), 'वैध JSON वापस आ गया है। @ सैंडी 505 हालांकि eval का उपयोग खतरनाक है, खासकर अगर डेटा तीसरे पक्ष के स्रोत से आता है क्योंकि आप नहीं जानते कि क्या पारित किया जा सकता है। यह आपके वेबपृष्ठ में इंजेक्शन वाले दुर्भावनापूर्ण कोड भी हो सकता है। वैसे भी वह PHP पक्ष नहीं है। –

0

संपत्ति के नामों को उद्धृत करने की आवश्यकता है। उदाहरण के लिए http://json.org/example.html देखें। मैं सर्वर को उचित JSON बनाने के लिए बदल दूंगा।

यह { "preOPen": "900", .... }

0

हां की तरह कुछ का निर्माण किया जाना चाहिए, यह विकृत है - कुंजी नाम के आसपास उद्धरण याद आ रही। आपको स्ट्रिंग के रूप में इसे स्वयं पार्स करने की आवश्यकता है ... या सर्वर पर फ़ाइल बदलें।

2

अधिकांश समाधानों में मुख्य रूप से कोलों के साथ कई समस्याएं होती हैं।

मैंने सरणी फ़ंक्शन के लिए एक जेसन लिखा जो इस समस्या को खत्म करता है।

यह जेसन स्ट्रिंग के चारों ओर गोल ब्रेसिज़ के लिए भी जांच करता है और इसे पूर्व json_decode हटा देता है।

function jsonDecode($string, $assoc=true, $fixNames=true){ 
    if(strpos($string, '(') === 0){ 
    $string = substr($string, 1, strlen($string) - 2); // remove outer (and) 
    } 
    if($fixNames){ 
    $string = preg_replace("/(?<!\"|'|\w)([a-zA-Z0-9_]+?)(?!\"|'|\w)\s?:/", "\"$1\":", $string); 
    } 
    return json_decode($string, $assoc); 
} 

यह भी कोलन से पहले खाली रिक्त स्थान के लिए जाँच करता है और उन्हें चर नाम से शामिल नहीं:

यहाँ कार्य है।

({शैली: "सीमा: 5px ठोस गुलाबी,", वर्ग:

यहाँ एक उदाहरण स्ट्रिंग मैं परीक्षण किया है "परीक्षण", "सही": "मूल्य", परीक्षण: सच है, var5: स्ट्रिंग "})

रूपांतरण के बाद" कुछ \ बच गए ":।

Array 
(
    [style] => border: 5px solid pink; 
    [class] => test 
    [correct] => value 
    [test] => 1 
    [var5] => some escaped" string 
) 

अब तक यह लग रहा है बुलेट प्रूफ

अगर आपको छेद मिल जाए तो मुझे बताएं।