代码演示:
import requests
# 程序入口
if __name__ == '__main__':
# 1.确定哦url
url_ = 'https://www.baidu.com/' # 以字符串的形式呈现
# 2.发送网络请求
response_ = requests.get(url_)
# 保存
with open('baidu.html', 'w') as f:
f.write(response_.text)
这里会出现报错:UnicodeEncodeError: 'gbk' codec can't encode character '\xe7' in position 318: illegal multibyte sequence
解决方式:但凡是见到UnicodeEncodeError错误,在读写操作中加上encoding='utf-8’基本就可以解决。
解决完成之后我们就可以拿到正确的结果了:
但是为什么会出现乱码的情况呢?
出现问题原因:
从网络请求拿下来的数据,都是字节类型的数据,我们使用text直接拿到的是字符串类型的数据,原因是:使用text会自动进行解码操作,但是会涉及到编解码格式的问题,但是text会自动识别编解码格式,然后进行解码操作,但是不一定准确,由于text自作多情 检测错了解码格式,因此出现了乱码的情况。
解决办法:直接使用content得到字节类型的数据,再使用解码方式进行解码:
import requests
# 程序入口
if __name__ == '__main__':
# 1.确定哦url
url_ = 'https://www.baidu.com/' # 以字符串的形式呈现
# 2.发送网络请求
response_ = requests.get(url_)
bytes_data = response_.content
str_data = bytes_data.decode('utf-8') # 使用正确的编码方式去解码,将字节数据解码成看得懂的字符数据,这样就可以避免乱码的问题。
# 保存
with open('baidu.html', 'w') as f:
f.write(response_.text)
正确结果如下: