详解用Python爬虫获取百度企业信用中企业基本信息


Posted in Python onJuly 02, 2020

一、背景

希望根据企业名称查询其经纬度,所在的省份、城市等信息。直接将企业名称传给百度地图提供的API,得到的经纬度是非常不准确的,因此希望获取企业完整的地理位置,这样传给API后结果会更加准确。
百度企业信用提供了企业基本信息查询的功能。希望通过Python爬虫获取企业基本信息。目前已基本实现了这一需求。
本文最后会提供具体的代码。代码仅供学习参考,希望不要恶意爬取数据!

二、分析

以苏宁为例。输入“江苏苏宁”后,查询结果如下:

详解用Python爬虫获取百度企业信用中企业基本信息

经过分析,这里列示的企业信息是用JavaScript动态生成的。服务器最初传过来的未经渲染的HTML如下:

详解用Python爬虫获取百度企业信用中企业基本信息

注意其中标注出来的JS代码。有意思的是,企业基本信息都可以直接从这段JS代码中获取,无需构造复杂的参数。

详解用Python爬虫获取百度企业信用中企业基本信息

这是进一步查看的结果,注意那个“resultList”,后面存放的就是页面中的企业信息。显然,利用正则表达式提取需要的字符串,转换成JSON就可以了。

三、源码

以下代码为查询某个企业的基本信息提供了API:

#!/usr/bin/env python
# -*- coding:utf-8 -*-
# @Author: Wild Orange
# @Email: jixuanfan_seu@163.com
# @Date:  2020-06-19 22:38:14
# @Last Modified time: 2020-07-01 17:33:13

import requests
import re
import json

headers={'User-Agent': 'Chrome/76.0.3809.132'}

#正则表达式提取数据
re_get_js=re.compile(r'<script>([\s\S]*?)</script>')
re_resultList=re.compile(r'"resultList":(\[{.+?}\]}])')

def Get_company_info(name):
	'''
		@func: 通过百度企业信用查询企业基本信息
	'''
	url='https://xin.baidu.com/s?q=%s'%name
	res=requests.get(url,headers=headers)
	if res.status_code==200:
		html=res.text
		retVal=_parse_baidu_company_info(html)
		return retVal
	else:
		print('无法获取%s的企业信息'%name)

def _parse_baidu_company_info(html):
	'''
		@function:解析百度企业信用提供的企业基本信息
		@output: list of dict, [{},{},...]
			pid: 跳转到具体企业页面的参数
			bid: 具体企业页面URL中的参数
			name: 企业名称
			type: 企业类型
			date: 成立日期
			address: 地址
			person: 法人代表
			status: 存续状态
			regCap: 注册资本
			scope: 经营范围
	'''
	js=re_get_js.findall(html)[1]
	data=re_resultList.search(js)
	if not data:
		return
	compant_list=json.loads(data.group(1))
	
	retVal=[]
	for x in compant_list:
		regCap=x['regCap'].replace(',','')
		if regCap[-1]=='万':
			regCap=regCap[:-1]
		regCap=float(regCap)
		address=x['domicile'].replace('<em>','').replace('</em>','')
		
		temp_v={'pid':x['pid'],'bid':x['bid'],'name':x['titleName'],'type':x['entType'],'date':x['validityFrom'],\
				'address':address,'person':x['legalPerson'],'status':x['openStatus'],'regCap':regCap,\
				'scope':x['scope']}
		retVal.append(temp_v)
	return retVal

四、使用方法

直接将需要查询的企业名称传入Get_company_info:

res=Get_company_info('江苏苏宁')
	print(res)

结果:

详解用Python爬虫获取百度企业信用中企业基本信息

需要注意的是:

返回的是字典构成的数组,每个字典元素代表一家企业的信息。顺序与浏览器中显示的顺序相同。字典中参数的含义已在_parse_baidu_company_info函数的注释中说明。程序仅获取第一页的信息。如果要查询多页,可以修改源码。程序仅获取企业的基本信息,没有进入企业的具体页面,如:苏宁物流具体页面。不过返回结果中的pid或bid应该能用于构造查询页面的URL。

最后再次强调:代码仅供学习参考,希望不要恶意爬取数据!

到此这篇关于详解用Python爬虫获取百度企业信用中企业基本信息的文章就介绍到这了,更多相关Python爬虫获取百度企业信用内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python下如何让web元素的生成更简单的分析
Jul 17 Python
python中的闭包用法实例详解
May 05 Python
基于Python实现通过微信搜索功能查看谁把你删除了
Jan 27 Python
Python和Perl绘制中国北京跑步地图的方法
Mar 03 Python
Python3用tkinter和PIL实现看图工具
Jun 21 Python
Python OOP类中的几种函数或方法总结
Feb 22 Python
python3.5安装python3-tk详解
Apr 26 Python
python给指定csv表格中的联系人群发邮件(带附件的邮件)
Dec 31 Python
使用Python打造一款间谍程序的流程分析
Feb 21 Python
Python pytesseract验证码识别库用法解析
Jun 29 Python
教你利用python实现企业微信发送消息
May 23 Python
Python基础学习之奇异的GUI对话框
May 27 Python
django 实现后台从富文本提取纯文本
Jul 02 #Python
详解用Python调用百度地图正/逆地理编码API
Jul 02 #Python
基于django2.2连oracle11g解决版本冲突的问题
Jul 02 #Python
解决django migrate报错ORA-02000: missing ALWAYS keyword
Jul 02 #Python
使用PyWeChatSpy自动回复微信拍一拍功能的实现代码
Jul 02 #Python
使用Keras建立模型并训练等一系列操作方式
Jul 02 #Python
python解释器安装教程的方法步骤
Jul 02 #Python
You might like
网页游戏开发入门教程三(简单程序应用)
2009/11/02 PHP
简单介绍win7下搭建apache+php+mysql开发环境
2015/08/06 PHP
php实现的单一入口应用程序实例分析
2015/09/23 PHP
phpmyadmin下载、安装、配置教程
2017/05/16 PHP
Mootools 1.2教程 选项卡效果(Tabs)
2009/09/15 Javascript
javascript 中__proto__和prototype详解
2014/11/25 Javascript
js实现进度条的方法
2015/02/13 Javascript
JavaScript实现模仿桌面窗口的方法
2015/07/18 Javascript
深入浅析JavaScript的API设计原则
2016/06/14 Javascript
javascript获取网页各种高宽及位置的方法总结
2016/07/27 Javascript
VueJS全面解析
2016/11/10 Javascript
JavaScript中一些特殊的字符运算
2017/08/17 Javascript
在vue中使用jsx语法的使用方法
2019/09/30 Javascript
js里面的变量范围分享
2020/07/18 Javascript
[48:11]完美世界DOTA2联赛 Magma vs GXR 第二场 11.07
2020/11/10 DOTA
在Django框架中设置语言偏好的教程
2015/07/27 Python
详解python3百度指数抓取实例
2016/12/12 Python
django项目中使用手机号登录的实例代码
2019/08/15 Python
wxPython多个窗口的基本结构
2019/11/19 Python
Python Pickle 实现在同一个文件中序列化多个对象
2019/12/30 Python
CSS3 新增选择器的实例
2019/11/13 HTML / CSS
Merrell美国官网:美国登山运动鞋品牌
2018/02/07 全球购物
世界上最具创新性的增强型知名运动品牌:Proviz
2018/04/03 全球购物
英国汽车零件购物网站:GSF Car Parts
2019/05/23 全球购物
Love, Bonito国际官网:新加坡女装品牌
2021/03/13 全球购物
西安众合通用.net笔试题
2013/03/18 面试题
C#基础面试题
2016/10/17 面试题
心理健康课教学反思
2014/02/13 职场文书
文明风采获奖感言
2014/02/18 职场文书
统计系教授推荐信
2014/02/28 职场文书
综治宣传月活动总结
2014/04/28 职场文书
我爱我班主题班会
2015/08/13 职场文书
污染环境建议书
2015/09/14 职场文书
企业廉洁教育心得体会
2016/01/20 职场文书
《田忌赛马》教学反思
2016/02/19 职场文书
分享15个Webpack实用的插件!!!
2021/03/31 Javascript