json是一种轻量级的数据交换格式,也可以说是一种配置文件的格式
这种格式的文件是我们在数据处理经常会遇到的
python提供内置的模块json,只需要在使用前导入即可
你可以通过帮助函数查看json的帮助文档
json常用的方法有load、loads、dump以及dumps,这个都属于python初级,我不做过多解释
json可以结合数据库一起使用,在这以后要处理大量数据时非常有用
下面我们正式来利用数据挖掘对json文件进行处理
现在很多网站都运用了Ajax,所以一般很多都是XHR文件
通过这里我想利用一个地图网站来演示
我们通过浏览器的调试获取了相关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])
在终端中运行结果如下
数据已经获取到了,但是为了接下来能使用这些数据,我们需要利用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方法,将返回的文本作为方法的参数传入
在终端中运行结果如下
可以看出,转换的结果是与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'])
下面在终端中运行这一段代码
可以看到里面有很多我们需要的数据,如
不一一标出,通过跟网页显示的相比较,就能清楚哪些是有用的了
下面我们通过代码获取有用的信息,把它清晰的输出
# 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'])
因为返回的是一个字典,通过对文件结构的研究,字典中嵌套着列表,列表中又嵌套着字典,通过层层解套,成功获取数据
我这里把步骤分开列出了,所以你会看的更加清楚
下面我们通过终端运行程序,获取我们想要的信息
是不是非常简单了,这个程序可以作为一个模版,获取其他地方的信息时只需要改一个url即可
例如以下几个范例
北京大学
或者是腾讯大厦
数据挖掘是没有尽头的,希望大家多分析数据,找到你想要的数据
顺丰-大数据挖掘与分析(2021秋招) 顺丰一面: 1.深挖实习,指标体系如何建立,各项指标的权重如何确定 2.逻辑回归算法的原理 3.谈谈对ABtest的认识 4.sql排序窗口函数的区别 顺丰二面: 1.深挖实习,预测为什么选用随机森林算法,如何调参 2.论文项目,简单介绍 3.了解哪些机器学习算法 4.反问 顺丰hr面 1.实习中遇到的困难,如何解决 2.过往经历中,你认为最困难的问题,你是
提问: 自我介绍 介绍一下你简历上的项目? 除了这个还做过其他的项目吗? 有没有参加过建模比赛? 对机器学习有了解吗? 总结: 面试官看起来是人事部门的,不像是技术人员,都没怎么问技术,很快就结束了。 心态上凑合,没上次那么紧张了。 老毛病又犯了呀我真的,跟对面那姐姐聊的太诚实了,机器学习那里我跟人说没怎么用过,回想起来就应该说一直有学习,也了解过,我真的悔死。虽然我也说了几种有监督和无监督的算法
这可能是一个非常愚蠢的问题,但我在其他任何地方都找不到答案,我已经看过了,但是我找不到与我的问题相关的答案。 问题: 在python中,不知道其他语言,每当我们调用一个内置类的if语句时,它会返回if语句解释的内容,例如, 如果为,则上述语句不会将任何内容打印为
众安保险-数据分析实习生 30min 个人介绍完了后直接写sql(给20min),未问简历。两道sql题在word写出完整代码,第二题太紧张有个地方理解错了,给面试官看了后还好及时发现,又给我五分钟重写hhh 反问:实习生做什么,主要是写sql满足业务方的需求。 喜马拉雅-数据分析实习生 30min 1、个人介绍。 2、问之前实习公司(初创小公司)是做什么的。对实习项目的成果(数据分析为用电安全提
1、自我介绍。 2、介绍自己做过的一个项目。 3、追问项目中的细节。 4、意向在青岛工作吗 反问 1、入职后会有培训吗 2、入职之后需要做哪些工作。 双人面试,没开摄像头,应该是同事面。感觉面试官都很友善。 虽然海尔在知乎被喷的挺惨,但面试印象还不错hhh 更新:关于牛友们的问题统一回答一下 1.有无英语测试 无 2. 测评后多久收到面试通知 3天左右,电话通知。之后短信发了面试链接。 3.有
本文向大家介绍深入分析jQuery.one() 函数,包括了深入分析jQuery.one() 函数的使用技巧和注意事项,需要的朋友参考一下 one()函数用于为每个匹配元素的一个或多个事件绑定一次性事件处理函数。 此外,你还可以额外传递给事件处理函数一些所需的数据。 通过one()函数绑定的事件处理函数都是一次性的,只有首次触发事件时会执行该事件处理函数。触发之后,jQuery就会移除当前事件绑定