最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Python3编码如何实现文件操作?

    正文概述    2020-03-18   207

    之前我们讲了编码之间相互转化的问题,有遗忘的小伙伴可以再去翻一下之间的内容,巩固了基础知识之后,就可以进入本篇用编码操作文件的学习了。因为今天的内容比较多,所以小伙伴们可以学习之前先保存一下,方便之后的回顾与查阅。其他的就不多讲了,下面小编带大家一起学习下Python3编码中实现文件的操作吧。


    想要通过 Python 代码操作某个文件,必须要有三个元素:

    • path:文件的路径

    • mode:r / w / r+ / w+ / a

    • encoding:编码方式

    2. 文件句柄包括:f / file / file_handler, f_h...

    3. open() 是内置函数,实际上是调用操作系统对文件操作的功能

    4. 各系统的默认编码方式:

    • Windows:GBK

    • Linux:UTF-8

    • IOS:UTF-8

    5. 对文件的任何操作都需要借助文件句柄

    6. f.close():打开某个文件后一定要记得关闭它,否则会一直在内存中占用资源

    7.打开某个文件并读取其中内容的方法:

    f = open("G:\test.txt", mode="r", encoding="utf-8")
    content = f.read()
    print(content)
    f.close()
     
    # 运行报错,原因解析:
    # 路径错误,系统会认为 \t 是一个转义字符
    # 解决办法:
    # 1) "G:\\test.txt"
    # 2) r"G:\test.txt"
    # 另外,这里不能把反斜杠 \ 改为斜杠 /,因为不同系统之间的斜杠与反斜杠之间会有不同的定义
     
    # 使用 open() 打开某个文件报错,除了上面提到的路径问题
    # 还有一个可能的原因,即编码问题
    # 比如在 Windows 系统上编写了一个 .txt 文件并保存
    # 在 Pycharm 里面打开该文件就会发现内容很有可能是乱码的
    # 原因就是两者的编码方式是不一样的

     

    8. 文件操作涉及到路径问题,路径分为两种: 

    • 绝对路径:从磁盘根目录开始,直到找到文件

    • 相对路径:从当前路径 (当前文件夹) 找到文件


    9. r 模型下的五种读取方式

    # 假设 test.txt 文件与本 Python 文件在同一个目录下
    # test.txt 文件里的内容如下:
    这是第一行的内容...
    这是第二行的内容...
    这是第三行的内容...
    这是第四行的内容...
    这是第五行的内容...
     
     
     
    ######## 1. read():全部读取出来 ########
    f = open("test.txt", mode="r", encoding="utf-8")
    content = f.read()
    print(content)
    f.close()
     
    # 运行结果:
    这是第一行的内容...
    这是第二行的内容...
    这是第三行的内容...
    这是第四行的内容...
    这是第五行的内容...
     
     
     
    ######## 2. read(n):读取 n 个字符 ########
    f = open("test.txt", mode="r", encoding="utf-8")
    content = f.read(3)
    print(content)
    f.close()
     
    # 运行结果:
    这是第
     
     
     
    ######## 3. readline():按行读取 ########
    f = open("test.txt", mode="r", encoding="utf-8")
    line1_content = f.readline()
    print(line1_content, type(line1_content))
    # 这是第一行的内容...
    # <class 'str'>
    line2_content = f.readline()
    print(line2_content, type(line2_content))
    # 这是第二行的内容...
    # <class 'str'>
    f.close()
     
     
     
    ######## 4. readlines():返回一个列表 ########
    f = open("test.txt", mode="r", encoding="utf-8")
    content = f.readlines()
    print(content)
    f.close()
     
    # 运行结果:
    ['这是第一行的内容...\n', '这是第二行的内容...\n', '这是第三行的内容...\n', '这是第四行的内容...\n', '这是第五行的内容...\n']
     
     
     
    ######## 5. for 循环:读取大文件 ########
    # 当一个文件很大时,比如它有 9G,但是电脑内存只有 8G
    # 如果使用上面的方法一次性全部读取出来,那么电脑就会挂掉
    # 解决办法就是使用 for 循环,只有每次循环时才占内存
    f = open("test.txt", mode="r", encoding="utf-8")
    for line in f:
        print(line.strip())
    f.close()
     
    # 运行结果:
    这是第一行的内容...
    这是第二行的内容...
    这是第三行的内容...
    这是第四行的内容...
    这是第五行的内容...
     
    # 如果是直接 print(line),注意看结果:
    这是第一行的内容...
     
    这是第二行的内容...
     
    这是第三行的内容...
     
    这是第四行的内容...
     
    这是第五行的内容...

    以上就是Python3编码实现文件操作的方法。不知道有小伙伴一次看明白了没有,给学会了的小伙伴点个赞。没有学会的小伙伴也不要着急,代码都在上面可以慢慢尝试,相信你们一定可以的。


    起源地下载网 » Python3编码如何实现文件操作?

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元