python--json

使用 JSON 函数需要导入 json 库:import json。

json.dumps      将 Python 对象编码成 JSON 字符串
json.loads      将已编码的 JSON 字符串解码为 Python 对象

json.dumps(obj, skipkeys=False, ensure_ascii=True,
check_circular=True,
allow_nan=True, cls=None, indent=None,
separators=None, encoding=“utf-8”, default=None,
sort_keys=False, **kw)

案例:

print(json.dumps({'a': 'Runoob', 'b': 7}, sort_keys=True, indent=4, separators=(',', ': ')))

import json

#python对象编码成为json的数据格式;
d = {'key%s' % (i): 'value%s' % (i) for i in range(1000)}
jsonStr = json.dumps(d)
print(jsonStr, type(jsonStr))
l = [1, 2, 3, 4]
jsonLi = json.dumps(l)
print(jsonLi, type(jsonLi))

#python对象编码为json格式, 并保存到制定文件中;
with open('doc/test01.json', 'w') as f:
    # indent: 是否设置缩进; sort_keys: 是否对key值进行排序;
    # separators = {"每个元素之间的分隔符", “key和value值之间的分隔符”}
    json.dump(d, f, indent=4, sort_keys=True, separators=(',', ': '))

#json对象解码成为python的数据格式;
pythonDict = json.loads(jsonStr)
print(pythonDict, type(pythonDict))

#json对象(存储在json文件)解码成为python的数据格式;
with open('doc/test01.json') as f:
    pythonObj = json.load(f)
    print(pythonObj, type(pythonObj))

指定IP地理位置的获取

#1. 简单的爬虫:
from urllib.request import urlopen

url = "http://ip-api.com/json/110.84.0.129"
urlObj = urlopen(url)

#服务端返回的页面信息, 此处为字符串类型
pageContent = urlObj.read().decode('utf-8')
print(pageContent)
print(type(pageContent))

#2. 处理Json数据
import json
#解码: 将json数据格式解码为python可以识别的对象;
dict_data = json.loads(pageContent)
print(dict_data)
print(type(dict_data))

print("""
所在城市: %s
所在国家: %s

""" %(dict_data['city'], dict_data['country']))

在这里插入图片描述
根据IP查询所在地、运营商等信息的一些API如下:
1. 淘宝的API(推荐):http://ip.taobao.com/service/getIpInfo.php?ip=110.84.0.129
2. 国外freegeoip.net(推荐):http://freegeoip.net/json/110.84.0.129 这个还提供了经纬度信息(但不一定准>)
3. 新浪的API:http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=json&ip=110.84.0.129
4. 腾讯的网页查询(返回的非json格式): http://ip.qq.com/cgi-bin/searchip?searchip1=110.84.0.129
5. ip.cn的网页(返回的非json格式):http://www.ip.cn/index.php?ip=110.84.0.129
6. ip-api.comhttp://ip-api.com/json/110.84.0.129

猜你喜欢

转载自blog.csdn.net/m0_37206112/article/details/86519490