python3源码文件以什么编码,Python3编码如何实现文件操作?

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

# 这是第一行的内容...

line2_content = f.readline()

print(line2_content, type(line2_content))

# 这是第二行的内容...

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

您可能感兴趣的文章:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值