json 格式化的时候报错

2019-01-09 12:35:49 +08:00
 Ewig

http://xxgk.miit.gov.cn/gdnps/searchIndex.jsp?params=%257B%2522goPage%2522%253A4%252C%2522orderBy%2522%253A%255B%257B%2522orderBy%2522%253A%2522publishTime%2522%252C%2522reverse%2522%253Atrue%257D%252C%257B%2522orderBy%2522%253A%2522orderTime%2522%252C%2522reverse%2522%253Atrue%257D%255D%252C%2522pageSize%2522%253A10%252C%2522queryParam%2522%253A%255B%257B%257D%252C%257B%257D%252C%257B%2522shortName%2522%253A%2522fbjg%2522%252C%2522value%2522%253A%2522%252F1%252F29%252F1146295%252F1652858%252F1652930%2522%257D%255D%257D&callback=jQuery111102456514014162614_1546997791362&_=1546997791366

我直接 json.loads(response.text)

返回的报错

Traceback (most recent call last): 780 File "/home/shenjianlin/.local/lib/python3.4/site-packages/twisted/internet/defer.py", line 653, in _runCallbacks 781 current.result = callback(current.result, *args, **kw) 782 File "/home/shenjianlin/my_project/Espider/Espider/spiders/xxgkmiit.py", line 31, in parse 783 _origin=json.loads(response.text) 784 File "/usr/lib64/python3.4/json/init.py", line 318, in loads 785 return _default_decoder.decode(s) 786 File "/usr/lib64/python3.4/json/decoder.py", line 343, in decode 787 obj, end = self.raw_decode(s, idx=_w(s, 0).end()) 788 File "/usr/lib64/python3.4/json/decoder.py", line 361, in raw_decode 789 raise ValueError(errmsg("Expecting value", s, err.value)) from None 790 ValueError: Expecting value: line 1 column 1 (char 0)

2581 次点击
所在节点    Python
18 条回复
Trim21
2019-01-09 12:37:40 +08:00
Sylv
2019-01-09 12:38:12 +08:00
把外围的 jQuery111102456514014162614_1546997791362(); 去掉才是合法 json 格式。
vincentxue
2019-01-09 13:05:39 +08:00
说明做了 MIIT 的程序员做了防 JSON 劫持。原因可以参见这里: http://www.10tiao.com/html/788/201811/2247489959/1.html
royzxq
2019-01-09 13:12:14 +08:00
请参考 #1 #2
ClutchBear
2019-01-09 13:15:05 +08:00
fan2006
2019-01-09 14:32:22 +08:00
Ewig
2019-01-09 15:11:45 +08:00
@fan2006 Traceback (most recent call last):
922 File "/home/shenjianlin/.local/lib/python3.4/site-packages/twisted/internet/defer.py", line 653, in _runCallbacks
923 current.result = callback(current.result, *args, **kw)
924 File "/home/shenjianlin/my_project/Espider/Espider/spiders/xxgkmiit.py", line 30, in parse
925 _origin=json.loads(response.text.split(');\r\n')[0][1:])
926 File "/usr/lib64/python3.4/json/__init__.py", line 318, in loads
927 return _default_decoder.decode(s)
928 File "/usr/lib64/python3.4/json/decoder.py", line 343, in decode
929 obj, end = self.raw_decode(s, idx=_w(s, 0).end())
930 File "/usr/lib64/python3.4/json/decoder.py", line 361, in raw_decode
931 raise ValueError(errmsg("Expecting value", s, err.value)) from None
932 ValueError: Expecting value: line 1 column 1 (char 0)
hoythan
2019-01-09 15:14:15 +08:00
@Sylv 加这个明明是为了 jsonp 好吗... callback(json)
Ewig
2019-01-09 15:16:11 +08:00
@Sylv 如何去掉呢
est
2019-01-09 15:18:15 +08:00
@Ewig python 面试题:

已知一个字符串 "callback(json)"

如何去掉外层的 callback() 得到 "json" 这个字符串
hoythan
2019-01-09 15:19:26 +08:00
wd
2019-01-09 15:20:20 +08:00
连字符串操作都不会还写什么代码。。。。
hoythan
2019-01-09 15:21:10 +08:00
原理就是 script 的方式加载接口解决跨域的问题,然后 js 内容是执行一个函数,至于函数名称就是 你自己定义的 callback
然后加载好 js 后就会跑你定义的 callback,你就可以拿到数据。
jsonp 知识了解下:
https://blog.csdn.net/hansexploration/article/details/80314948
hoythan
2019-01-09 15:24:50 +08:00
@Sylv @错人了

应该是 @vincentxue
hoythan
2019-01-09 15:25:54 +08:00
Sylv
2019-01-09 15:32:21 +08:00
@hoythan 我了解这是为了 jsonp,但是 lz 的需求是用 Python 读取这段 json,最直接的方法就是去掉 callback() 后 json.loads,他肯定不懂且也不需要去了解 jsonp 知识。
Sylv
2019-01-09 15:35:47 +08:00
@Ewig 如果你不知道如何去掉外围的字符串,我建议你是停下来先认真学习一遍 Python 和编程基础知识。
vincentxue
2019-01-10 10:04:35 +08:00
@hoythan 受教了,看走眼了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/525333

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX