美文网首页Python爬虫作业
Python 读写文件的编码与解码问题

Python 读写文件的编码与解码问题

作者: 倔强的潇洒小姐 | 来源:发表于2017-08-30 19:08 被阅读2937次

本文通过使用 Python 中的 with 来读写 word 文档,遇到文本的编码与解码问题,试了下面很多种方法,依旧没有不能将 word 文件的内容打印出来


最终通过文件格式转化来实现的,请见最后代码描述

演示文件为docx文档,内容如下:


Word文件内容.png

源码

with open('C:/Users/zhangXXX/Desktop/test.docx') as f:
line = f.read()
print(line)

运行源码查看报错信息
UnicodeDecodeError: 'gbk' codec can't decode byte 0xab in position 15: illegal multibyte sequence

上述错误是一种很常见的解码错误,下面介绍该错误的解决方法

1)打开文件时设置编码格式,如 encoding=’gbk’ 或者'utf-8'
 with open('C:/Users/zhangXXX/Desktop/test.docx', encoding=’gbk’) as f:
2)若(1)不能解决,可能是文本中出现的一些特殊符号超出了gbk的编码范围,可以选择编码范围更广的‘gb18030’
 with open('C:/Users/zhangXXX/Desktop/test.docx', encoding='gb18030') as f:
3)若(2)仍不能解决,说明文中出现了连‘gb18030’也无法编码的字符,可以使用‘ignore’属性进行忽略,但输出结果是乱码
 with open('C:/Users/zhangXXX/Desktop/test.docx', encoding='gb18030', errors='ignore') as f:
文件输出是乱码.png

把utf-8,gbk等各种编码方式都试了一遍,还是没有解决问题然后仔细看报错信息,根据UnicodeDecodeError: 'utf-8' codec can't decode byte 0xfb in position 14: invalid start byte,猜测文件中某个字节不能解码,打开文件一看,并没有看出什么问题来

4)TypeError: an integer is required (got type str)

open() 函数的第三个参数不是用来接收编码方式的,而是传入一个buffering的值,此处传入了'gbk'字符串,所以系统提示传一个整型

with open('C:/Users/zhangXXX/Desktop/海口.docx', 'rb', 'gbk') as f:

文件转化方法步骤:

通过调用office的API进行操作,因为在office上能完成的操作,都能通过win32完成,所以我们选择使用win32
(Python3.5 需要安装 win32compat,里面含了 win32 的很多包)

1、安装第三方库:win32compat
pip install  win32compat
2、将文件转化为文本格式 后再次打开输出(先将文件转化为doc格式)
# test for with.py
# -*- coding: utf-8 -*-
# __author__ = 'Carina'

from win32com import client as wc

word = wc.Dispatch('Word.Application')
doc = word.Documents.Open(r'C:/Users/Carina/Desktop/海口1.doc')
doc.SaveAs('C:/Users/Carina/Desktop/海口2',4)
doc.Close()
word.Quit()

with open(r'C:\Users\Carina\Desktop\海口2.txt','r') as f:
    line = f.read()
    print(line)
调试过程png

总结

读取文件内容的方式常见有3种:
file.read()
file.readlines()
file.readline()

相关文章

  • Python 读写文件的编码与解码问题

    本文通过使用 Python 中的 with 来读写 word 文档,遇到文本的编码与解码问题,试了下面很多种方法,...

  • Python ☞ day 5

    Python学习笔记之 装饰器& 偏函数 & 异常处理 & 断言 & 文件读写 &编码与解码 装饰器 概念:是一个...

  • 编码与解码问题

    编码与解码 对于我这样的新手来说python2.x的编码解码问题真是个坑,什么decode,encode,好乱好乱...

  • 【学习】爬虫学习

    一、python3版本encode和decode的问题 查看python版本: python3中的编码和解码与py...

  • python入门 第二天 str

    编码与解码# -*- coding:utf-8 -*-# python2.x中使用temp = "张三"# 解码需...

  • python io 编程

    文件读写 读取文件 写文件 延展,非UTF-8编码的文本文件读写需要: 所有模式的定义及含义可以参考Python的...

  • url解码

    在爬虫或者python的一些文件下载过程中经常碰到的一个问题就是对url进行编码和解码,python提供了很方便的...

  • IO编程

    读文件 字符编码 要读取非ASCII编码的文件,要以二进制模式打开,再解码。 Python还提供了一个codecs...

  • python学习笔记|数据格式化——JSON解析

    Json解析包括编码(encoding)与解码(decoding)。编码是将python数据类型转换为json格式...

  • 关于python中编码与解码的问题

    部分来源于网络整理 一、计算机的编码与解码 探讨编码与解码问题前,首先要知道什么是编码?什么是解码?计算机最终存储...

网友评论

    本文标题:Python 读写文件的编码与解码问题

    本文链接:https://www.haomeiwen.com/subject/bmemdxtx.html