深入分析python数据挖掘 Json结构分析


Posted in Python onApril 21, 2018

深入分析python数据挖掘 Json结构分析

json是一种轻量级的数据交换格式,也可以说是一种配置文件的格式

深入分析python数据挖掘 Json结构分析

这种格式的文件是我们在数据处理经常会遇到的

python提供内置的模块json,只需要在使用前导入即可

深入分析python数据挖掘 Json结构分析 

你可以通过帮助函数查看json的帮助文档

深入分析python数据挖掘 Json结构分析

json常用的方法有load、loads、dump以及dumps,这个都属于python初级,我不做过多解释

json可以结合数据库一起使用,在这以后要处理大量数据时非常有用

下面我们正式来利用数据挖掘对json文件进行处理

现在很多网站都运用了Ajax,所以一般很多都是XHR文件

通过这里我想利用一个地图网站来演示

深入分析python数据挖掘 Json结构分析

我们通过浏览器的调试获取了相关url

https://ditu.amap.com/service/poiInfo?id=B001B0IZY1&query_type=IDQ

下面我们通过requests模块中的get方法,模拟浏览器发出的http请求,并返回的到的结果对象

代码如下

# coding=utf-8
__Author__ = "susmote"

import requests
url = "https://ditu.amap.com/service/poiInfo?id=B001B0IZY1&query_type=IDQ"

resp = requests.get(url)
print(resp.text[0:200])

在终端中运行结果如下

深入分析python数据挖掘 Json结构分析

数据已经获取到了,但是为了接下来能使用这些数据,我们需要利用json模块对这些数据进行分析

代码如下

import requests
import json

url = "https://ditu.amap.com/service/poiInfo?id=B001B0IZY1&query_type=IDQ"

resp = requests.get(url)

json_dict = json.loads(resp.text)

print(type(json_dict))

print(json_dict.keys())

简单讲一下上面的代码:

导入json模块,然后调用loads方法,将返回的文本作为方法的参数传入 

在终端中运行结果如下 

深入分析python数据挖掘 Json结构分析

 可以看出,转换的结果是与json字符串对应的字典,因为type(json_dict)返回的是<class 'dict'>

因为对象是一个字典,所以我们可以调用字典的方法,在这里我们调用的就是keys方法

结果返回三个键,即status、searcOpt、data

下面我们来查看data键里面的数据

import requests
import json

url = "https://ditu.amap.com/service/poiInfo?id=B001B0IZY1&query_type=IDQ"

resp = requests.get(url)

json_dict = json.loads(resp.text)

print(json_dict['data'])

下面在终端中运行这一段代码

深入分析python数据挖掘 Json结构分析

可以看到里面有很多我们需要的数据,如 

深入分析python数据挖掘 Json结构分析

不一一标出,通过跟网页显示的相比较,就能清楚哪些是有用的了

下面我们通过代码获取有用的信息,把它清晰的输出

# coding=utf-8
__Author__ = "susmote"

import requests
import json

url = "https://ditu.amap.com/service/poiInfo?id=B001B0IZY1&query_type=IDQ"

resp = requests.get(url)

json_dict = json.loads(resp.text)

data_dict = json_dict['data']

data_list = data_dict['poi_list']

dis_data = data_list[0]

print('城市: ', dis_data['cityname'])
print('名称: ', dis_data['name'])
print('电话: ', dis_data['tel'])
print('区号: ', dis_data['areacode'])
print('地址: ', dis_data['address'])
print('经度: ', dis_data['longitude'])
print('纬度: ', dis_data['latitude'])

 因为返回的是一个字典,通过对文件结构的研究,字典中嵌套着列表,列表中又嵌套着字典,通过层层解套,成功获取数据

我这里把步骤分开列出了,所以你会看的更加清楚

下面我们通过终端运行程序,获取我们想要的信息 

深入分析python数据挖掘 Json结构分析

是不是非常简单了,这个程序可以作为一个模版,获取其他地方的信息时只需要改一个url即可

例如以下几个范例

北京大学 

深入分析python数据挖掘 Json结构分析

 

或者是腾讯大厦

深入分析python数据挖掘 Json结构分析

数据挖掘是没有尽头的,希望大家多分析数据,找到你想要的数据

Python 相关文章推荐
C#返回当前系统所有可用驱动器符号的方法
Apr 18 Python
Python使用PyCrypto实现AES加密功能示例
May 22 Python
Python微信库:itchat的用法详解
Aug 14 Python
Python 内置函数进制转换的用法(十进制转二进制、八进制、十六进制)
Apr 30 Python
利用Python将文本中的中英文分离方法
Oct 31 Python
Python 判断图像是否读取成功的方法
Jan 26 Python
解决Python安装时报缺少DLL问题【两种解决方法】
Jul 15 Python
python 判断三个数字中的最大值实例代码
Jul 24 Python
Python+redis通过限流保护高并发系统
Apr 15 Python
Python中常见的数制转换有哪些
May 27 Python
python中使用np.delete()的实例方法
Feb 01 Python
一文搞懂python异常处理、模块与包
Jun 26 Python
Python编程中NotImplementedError的使用方法
Apr 21 #Python
python 通过字符串调用对象属性或方法的实例讲解
Apr 21 #Python
python 限制函数调用次数的实例讲解
Apr 21 #Python
python装饰器-限制函数调用次数的方法(10s调用一次)
Apr 21 #Python
对Python中的@classmethod用法详解
Apr 21 #Python
python3+dlib实现人脸识别和情绪分析
Apr 21 #Python
Python通过属性手段实现只允许调用一次的示例讲解
Apr 21 #Python
You might like
数组与类使用PHP的可变变量名需要的注意的问题
2013/06/20 PHP
用php来限制每个ip每天浏览页面数量的实现思路
2015/02/24 PHP
PHP中的traits简单使用实例
2015/05/13 PHP
十个PHP高级应用技巧果断收藏
2015/09/25 PHP
理清PHP在Linxu下执行时的文件权限方法
2017/06/07 PHP
javascript 出生日期和身份证判断大全
2008/11/13 Javascript
JS 日期比较大小的简单实例
2014/01/13 Javascript
js replace替换所有匹配的字符串
2014/02/13 Javascript
浅析AngularJS中的生命周期和延迟处理
2015/06/18 Javascript
Bootstrap表单布局样式代码
2016/05/31 Javascript
AngularJS入门教程之AngularJS 模板
2016/08/18 Javascript
轻松掌握JavaScript策略模式
2016/08/25 Javascript
js改变透明度实现轮播图的算法
2020/08/24 Javascript
NodeJS中的MongoDB快速入门详细教程
2016/11/11 NodeJs
Vue 短信验证码组件开发详解
2017/02/14 Javascript
解决vue axios的封装 请求状态的错误提示问题
2018/09/25 Javascript
详解Vue.js在页面加载时执行某个方法
2018/11/20 Javascript
浅谈react-router@4.0 使用方法和源码分析
2019/06/04 Javascript
利用js canvas实现五子棋游戏
2020/10/11 Javascript
antd Form组件方法getFieldsValue获取自定义组件的值操作
2020/10/29 Javascript
[20:39]DOTA2-DPC中国联赛 正赛开幕式 1月18日
2021/03/11 DOTA
跟老齐学Python之再深点,更懂list
2014/09/20 Python
关于python的bottle框架跨域请求报错问题的处理方法
2017/03/19 Python
Python使用Tkinter实现机器人走迷宫
2018/01/22 Python
python实现京东秒杀功能
2018/07/30 Python
python整小时 整天时间戳获取算法示例
2019/02/20 Python
通过Turtle库在Python中绘制一个鼠年福鼠
2020/02/03 Python
Python通过文本和图片生成词云图
2020/05/21 Python
Python基于smtplib协议实现发送邮件
2020/06/03 Python
Vision Direct比利时:在线订购隐形眼镜
2019/08/27 全球购物
德国前卫设计师时装在线商店:Luxury Loft
2019/11/04 全球购物
德国珠宝和配件商店:Styleserver
2021/02/23 全球购物
优秀实习自我鉴定
2013/12/04 职场文书
小组名称和口号
2014/06/09 职场文书
四风问题个人自查剖析材料思想汇报
2014/09/21 职场文书
SpringBoot项目多数据源及mybatis 驼峰失效的问题解决方法
2022/07/07 Java/Android