Python解析json之ValueError: Expecting property name enclosed in double quotes: line 1 column 2(char 1)
前言
在Python中提供了json包來(lái)方便快捷的解析json字串的轉(zhuǎn)換過(guò)程,但是碰到了一個(gè)比較奇怪的問(wèn)題,就是不太正確的json串如何來(lái)解析?
1. 問(wèn)題的提出
今天在處理一個(gè)http請(qǐng)求的響應(yīng)json之時(shí),基于python進(jìn)行解析,碰到了如下錯(cuò)誤:
Traceback (most recent call last): File "<ipython-input-16-bff463ed9408>", line 1, in <module> json.loads(r.text) File "/Users/tonychen/anaconda2/lib/python2.7/json/__init__.py", line 339, in loads return _default_decoder.decode(s) File "/Users/tonychen/anaconda2/lib/python2.7/json/decoder.py", line 364, in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) File "/Users/tonychen/anaconda2/lib/python2.7/json/decoder.py", line 380, in raw_decode obj, end = self.scan_once(s, idx) ValueError: Expecting property name enclosed in double quotes: line 1 column 2 (char 1)
看來(lái)是解析json的時(shí)候出錯(cuò)了....
代碼如下:
import json import requests user_agent = "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; AcooBrowser; .NET CLR 1.1.4322; .NET CLR 2.0.50727)" def get_header(): return { 'User-Agent': user_agent, 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8', 'Accept-Language': 'en-US,en;q=0.5', 'Connection': 'keep-alive', 'Accept-Encoding': 'gzip, deflate', } TEST_URL = 'http://ip.chinaz.com/getip.aspx' r = requests.get(url=TEST_URL, headers=get_header(), timeout=5) jsonstr = json.loads(r.text) print(jsonstr)
報(bào)錯(cuò)的代碼行: json.loads(r.text)
那問(wèn)題出在哪里呢?
2. 問(wèn)題的分析
讓我們先來(lái)看看,r.text中的信息是什么吧:
>> r.text
u"{ip:'103.47.146.9',address:'\u4e9a\u592a\u5730\u533a '}"
仔細(xì)觀察之后,發(fā)現(xiàn)其實(shí)應(yīng)該是ip,address的字段沒有相應(yīng)的引號(hào)來(lái)包裝,所以json無(wú)法正確的進(jìn)行字符串的處理
那正確的json串格式應(yīng)該是什么樣子呢?我們來(lái)做個(gè)樣例看一下
>> json1 = {'key1': 'val1', 'key2':'val2'}
>> json.dumps(json1)
'{"key2": "val2", "key1": "val1"}'
正如我們?cè)谏衔闹刑岬降膯?wèn)題,應(yīng)該是key沒有正確的被括起來(lái)。
3. 問(wèn)題的解決
知道問(wèn)題出在哪里之后,我們就可以針對(duì)性地進(jìn)行解決了。問(wèn)題的解決思路有兩條:
a. 針對(duì)字符串來(lái)進(jìn)行處理,保證字符串符合json的格式要求
b. 借助第三方包的幫助順利解決這個(gè)問(wèn)題
相比而言,方案b可以簡(jiǎn)便和易用,我們這里使用了demjson的包來(lái)處理這個(gè)問(wèn)題。
安裝: pip install demjson
使用: json_obj = demjson(json_string)
簡(jiǎn)單的一個(gè)調(diào)用就將這個(gè)問(wèn)題一掃而光,是不是非常的簡(jiǎn)單易用呀?
4. demjson的介紹
快速說(shuō)明: http://deron.meranda.us/python/demjson/
demjson有兩個(gè)主要的方法:
encode 編碼,將對(duì)象轉(zhuǎn)換為json
decode 解碼,將json轉(zhuǎn)化為對(duì)象
總結(jié)
這個(gè)問(wèn)題的產(chǎn)生主要還是服務(wù)端在進(jìn)行json轉(zhuǎn)換的過(guò)程中沒有很好處理好這個(gè)問(wèn)題造成的,正常來(lái)說(shuō),一般不應(yīng)該出現(xiàn)的的。
好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
- Python如何爬取微信公眾號(hào)文章和評(píng)論(基于 Fiddler 抓包分析)
- 解決Python報(bào)錯(cuò):ValueError:operands?could?not?be?broadcast?together?with?shapes
- Python異常?ValueError的問(wèn)題
- 關(guān)于 Python opencv 使用中的 ValueError: too many values to unpack
- Python ValueError: invalid literal for int() with base 10 實(shí)用解決方法
- 使用fiddler抓包工具Python requests報(bào)錯(cuò):ValueError: check_hostname requires server_hostname的解決
相關(guān)文章
Python3 中把txt數(shù)據(jù)文件讀入到矩陣中的方法
下面小編就為大家分享一篇Python3 中把txt數(shù)據(jù)文件讀入到矩陣中的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-04-04Pytorch中的model.train()?和?model.eval()?原理與用法解析
pytorch可以給我們提供兩種方式來(lái)切換訓(xùn)練和評(píng)估(推斷)的模式,分別是:model.train()?和?model.eval(),這篇文章主要介紹了Pytorch中的model.train()?和?model.eval()?原理與用法,需要的朋友可以參考下2023-04-04解決ImportError:DLL load failed while impo
在安裝pywin32后,可能會(huì)出現(xiàn)無(wú)法導(dǎo)入win32api的錯(cuò)誤,一個(gè)有效的解決方案是運(yùn)行pywin32_postinstall.py腳本,首先,打開cmd并切換到環(huán)境的Scripts文件夾,確保存在pywin32_postinstall.py文件2024-09-09Python入門之使用pandas分析excel數(shù)據(jù)
這篇文章主要給大家介紹了關(guān)于Python入門學(xué)習(xí)之使用pandas分析excel數(shù)據(jù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用python具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05python如何通過(guò)openpyxl讀寫Excel文件
python操作excel的庫(kù)有很多,有的庫(kù)只能讀取xsl格式,比如xlrd庫(kù),有的庫(kù)只能寫xsl格式,比如xlwt庫(kù),有的只能讀寫xslx格式,比如openpyxl庫(kù),綜合各庫(kù)及 xslx 格式比較常見,所以本文主要講解openpyxl庫(kù)對(duì)xslx格式的excel操作,需要的朋友可以參考下2023-10-10