Python 编码问题:‘ascii‘ codec can‘t encode characters in position 8-50: ordinal not in range(128) 实操解决办法

在Python3.6中遇到'ascii' codec无法编码位置8-50的字符,原因是中文符号编码问题。解决方案是使用urllib.parse.quote函数,通过设置safe参数来处理URL中的特殊字符,例如将中文路径转换为可读URL。然后使用pandas读取Excel文件并将其转换为字典记录,以便进一步处理。

版本 Python 3.6

报错:

'ascii' codec can't encode characters in position 8-50: ordinal not in range(128)

究其原因就是中文符号的编码问题

解决:

import pandas as pd
import urllib.parse

path = 'https:xxx.com/(牛牛).xls'

# safe 为无需转码的字符
url = urllib.parse.quote(path,safe=":/=?#")

dates = pd.read_excel(url,keep_default_na=False).to_dict(orient='records')

print(dates)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值