爬虫爬下的html是乱码,pyhon爬虫中文乱码

pyhon爬虫中文乱码

爬到的网页,在调试模式看着是中文,用输出看也是中文,但是存入变量就编码格式不对了。

问题出现的环境背景及自己尝试过哪些方法

下面是源码

#coding: utf-8

import requests

import json

from bs4 import BeautifulSoup

url = 'https://www.3ajiepai.com/forum-190-1.html'

strhtml = requests.get(url)

# 由于目标是gbk,接受到的是乱码,所以这里需要转换编码格式

strhtml.encoding = 'gb18030'

soup = BeautifulSoup(strhtml.content, "html.parser")

print soup.original_encoding

print soup.title

data = soup.select('#waterfall li')

list = []

for item in data:

imgs = item.find('img')

name = item.select(".xw0 a")[0]

author = item.select(".auth.cl .a_name a")[0]

names = name.text.encode("utf8")

result = {

"name": names,

}

print (result)

list.append(result)

print (list)

# 写入本地文件

test_dict = { 'start': list}

json_str = json.dumps(test_dict)

new_dict = json.loads(json_str)

with open('data.json', 'w') as f:

json.dump(new_dict, f)

print("写入文件完毕。。。")

下图是调试模式图片

bVbxJoj?w=1458&h=1508

下图是控制输出图片

bVbxJok?w=2262&h=1198

下图是生成文件图片

bVbxJos?w=1954&h=184

求大神帮忙解决中文编码乱码问题,不胜感激。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值