Python爬虫——城市公交、地铁站点和线路数据采集
时间: 2023-11-23 14:07:08 浏览: 157
采集城市公交、地铁站点和线路数据可以帮助我们更好地了解城市公共交通系统的运作情况,为城市交通规划和出行提供参考。下面是一个基于Python的爬虫示例,可以用来采集城市公交、地铁站点和线路数据。
1. 确定爬取的网站
首先需要确定你想要采集的城市公交、地铁站点和线路数据所在的网站。常见的网站有:
- 公交线路查询网站,如高德地图、百度地图等;
- 公交、地铁运营公司的官方网站;
- 公交、地铁相关的开放数据平台,如城市公共交通数据开放平台等。
2. 分析网站结构
在确定了采集的网站后,需要分析网站的结构,了解需要爬取的数据所在的页面、标签和属性等信息。可以使用开发者工具来帮助分析网站结构。
3. 使用Python爬虫代码采集数据
在分析了网站结构后,可以使用Python编写爬虫代码来采集数据。其中需要用到的模块包括:
- requests:用于发送HTTP请求,获取网页内容;
- BeautifulSoup4:用于解析HTML页面,提取所需数据;
- pandas:用于数据处理和存储。
下面是一个示例代码,可以爬取高德地图上北京市公交线路数据:
```python
import requests
from bs4 import BeautifulSoup
import pandas as pd
# 获取公交线路列表页面
url = 'https://ditu.amap.com/bus/beijing'
r = requests.get(url)
# 解析HTML页面,获取所有公交线路名称及其链接
soup = BeautifulSoup(r.text, 'html.parser')
lines = soup.find_all('a', {'class': 'bus-tit'})
# 遍历每个公交线路,获取站点信息
data = []
for line in lines:
line_name = line.text
line_url = 'https:' + line['href']
r = requests.get(line_url)
soup = BeautifulSoup(r.text, 'html.parser')
stations = soup.find_all('div', {'class': 'station-name'})
station_names = [s.text for s in stations]
data.append({'line': line_name, 'stations': station_names})
# 将数据保存为CSV文件
df = pd.DataFrame(data)
df.to_csv('bus_lines.csv', index=False)
```
运行以上Python代码后,将会在当前文件夹下生成一个名为bus_lines.csv的CSV文件,其中包含了所有北京市公交线路及其站点信息。
以上示例代码仅为一个简单的示例,实际应用中可能需要更复杂的爬虫代码来处理数据。同时,需要注意合法使用爬虫,遵守相关法律法规。
阅读全文