```import requests
import csv
import time
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.146 Safari/537.36'
}
url = 'https://www.mafengwo.cn/jd/10065/gonglve.html'
# 发送请求获取页面信息
response = requests.get(url, headers=headers)
# 解析页面信息,获取每个景点的链接
from bs4 import BeautifulSoup
soup = BeautifulSoup(response.text, 'html.parser')
jd_links = []
jd_names = []
for item in soup.select('.hot-list .item a.img'):
jd_links.append(item['href'])
jd_names.append(item['title'])
# 定义保存数据的文件名
filename = '青岛景点信息.csv'
# 打开文件,设置文件模式为w,即写入模式
with open(filename, mode='w', encoding='utf-8', newline='') as f:
# 创建csv写入对象
writer = csv.writer(f)
# 写入表头
writer.writerow(['景点名称', '经度', '纬度', '历史人流量', '消费金额', '评论数'])
for jd_link, jd_name in zip(jd_links, jd_names):
print(f'正在爬取景点:{jd_name}...')
# 发送请求获取景点页面信息
jd_response = requests.get(jd_link, headers=headers)
jd_soup = BeautifulSoup(jd_response.text, 'html.parser')
# 获取经纬度
try:
jd_lng, jd_lat = jd_soup.select('.bd-map-js')[0]['data-point'].split(',')
except:
jd_lng, jd_lat = None, None
# 获取历史人流量和消费金额
jd_info_items = jd_soup.select('.info-item')
jd_history_visitor_num = None
jd_consume_amount = None
for jd_info_item in jd_info_items:
if '历史人流量' in jd_info_item.text:
jd_history_visitor_num = jd_info_item.select('.num')[0].text
elif '人均消费' in jd_info_item.text:
jd_consume_amount = jd_info_item.select('.num')[0].text
# 获取评论数
try:
jd_comment_num = jd_soup.select('.rev-total')[0].text.split('条')[0]
except:
jd_comment_num = None
# 将数据写入csv文件
writer.writerow([jd_name, jd_lng, jd_lat, jd_history_visitor_num, jd_consume_amount, jd_comment_num])
# 休眠1秒,防止频繁访问被封IP
time.sleep(1)
print('数据爬取完成!')
关于#python#的问题,如何解决?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
6条回答 默认 最新
- lshen01 2023-03-18 22:25关注
参考GPT和自己的思路:
这段代码是用来爬取青岛各个景点的经纬度、历史人流量、消费金额和评论数,并将数据保存在csv文件中。如果你遇到了关于这段代码的问题,可以具体说明你遇到的问题和错误,以便我更好地帮助你解决问题。
解决 无用评论 打赏 举报
悬赏问题
- ¥20 关于游戏c++语言代码问题
- ¥15 如何制作永久二维码,最好是微信也可以扫开的。(相关搜索:管理系统)
- ¥15 delphi indy cookie 有效期
- ¥15 labelme打不开怎么办
- ¥35 按照图片上的两个任务要求,用keil5写出运行代码,并在proteus上仿真成功,🙏
- ¥15 免费的电脑视频剪辑类软件如何盈利
- ¥30 MPI读入tif文件并将文件路径分配给各进程时遇到问题
- ¥15 pycharm中导入模块出错
- ¥20 Ros2 moveit2 Windows环境配置,有偿,价格可商议。
- ¥15 有关“完美的代价”问题的代码漏洞