即使有 encoding = 'utf-8-sig'语句,但是用excel打开还是会有乱码,求解

def save_to_csv(result):

    fieldname = ['id','text','attitudes','comments','reposts']
    with open('data.csv','a+',encoding = 'utf-8-sig',newline = '')as csv_file:
        writer = csv.DictWriter(csv_file,fieldnames = fieldname)
        csv_file.seek(0)
        line = csv_file.readline()
        if line:
            csv_file.seek(2)
            writer.writerow(result)
        else:
            csv_file.seek(2)
            writer.writeheader()
            writer.writerow(result)

 

encoding = 'utf-8-sig'

改为

encoding = 'utf-8'

试试

excel默认是以gbk编码打开csv文件的,应该设置encoding = 'gbk'

试试encoding='gbk',或者encoding='utf8',总有一个可以解决题主的问题。

您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

速戳参与调研>>>https://t.csdnimg.cn/Kf0y

'a'改为'w'