Qwerthd 2023-03-07 17:40 采纳率: 71.1%
浏览 20
已结题

关于#python#的问题,如何解决?

python爬虫遇字符识别失败问题
就是我想将爬到的数据p.text写入文件中,它报错 了

img


对于字符转换这一块还是搞不太清除


import requests
from bs4 import  BeautifulSoup
import io
import sys
import urllib.request
sys.stdout = io.TextIOWrapper(sys.stdout.buffer,encoding='utf8') #改变标准输出的默认编码
# -------------------------------------------------------------历届中国女子排球联赛获奖名单-----------------------------------------------------------------------------------

#UA伪装
headers={"user-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) A" "ppleWebKit/537.36 (KHTML, like Gecko) Chrome/107.0.0.0 Safari/537.36"
}
#1.指定爬虫网页网址
url="http://www.volleychina.org/hv/2023-01-19/doc-imyaterk5587468.shtml"

# 2.对URL发起请求
requests.get(url=url,headers=headers)

# 3.获取响应数据
response = requests.get(url=url,headers=headers)
page_txt = response.content.decode('utf-8')
# page_txt.encoding='utf_8'

# 4数据解析
#通过BeautifulSoup解析数据
#① 实例化BeautifulSoup对象,将页面数据加载至对象,Fe_Re_soup为女性获奖对象
Fe_Re_soup=BeautifulSoup(page_txt,'lxml')
#② 解析url标签属性等
#将div<detail-context>标签下所有的p标签提取
p_list=Fe_Re_soup.select('.detail-context>p')

#提取所有p标签下span标签里的内容,注p类型为bs4.element.Tag
f=open('女排球员获奖数据.txt','w+')
for p in p_list:
    print(type (p.text))
    f.write(p.text)
    print('over')
# 5.存储数据
  • 写回答

3条回答 默认 最新

  • 「已注销」 2023-03-07 18:06
    关注

    “Devil组”引证GPT后的撰写:
    这个错误是由于文件写入时使用的默认编码为 'gbk',而 p.text 中含有无法被 'gbk' 编码的字符。可以将文件的编码格式改为 'utf-8',这样就可以处理中文和其他特殊字符。在打开文件时,指定 'utf-8' 编码格式即可:

    f = open('女排球员获奖数据.txt', 'w+', encoding='utf-8')
    
    
    

    这样就可以正常将 p.text 内容写入文件了。同时,也不需要在代码中添加 sys.stdout 和 io 模块的编码转换语句,因为这些操作只影响标准输出流的编码,而不影响文件输出流的编码。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月16日
  • 已采纳回答 3月8日
  • 创建了问题 3月7日

悬赏问题

  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来