在 Python 中逐字符读取文件

Python 中逐个字符读取文件:

  1. 以读模式打开文件。
  2. 使用 file.read(1) 方法在 while 循环中逐字符读取文件。
  3. 使用 break 语句在文件末尾退出循环。
with open('example.txt', 'r', encoding='utf-8') as file:
    while True:
        char = file.read(1)

        if not char:
            print('Reached end of file')
            break

        print(char)

代码示例假定我们在同一目录中有一个 example.txt 文件。

如果我们正在以二进制模式读取文件,则 size 表示要从文件中读取的字节大小。

我们将 size 参数设置为 1 以逐字符读取文件。

如果已到达文件末尾,则 file.read() 方法返回一个空字符串。

如果条件满足,我们使用break语句退出while循环。

break 语句跳出最里面的 for 或 while 循环。

如果需要将单个字符添加到列表中,可以使用 append() 方法。

with open('example.txt', 'r', encoding='utf-8') as file:
    characters = []

    while True:
        char = file.read(1)

        if not char:
            print('Reached end of file')
            break

        characters.append(char)
        print(char)

    print(characters)  # 👉️ ['a', 'p', 'p', 'l', 'e']

在 while 循环的每次迭代中,我们将当前字符添加到列表中。

list.append() 方法将一个项目添加到列表的末尾。

或者,我们可以使用 for 循环。


使用 for 循环逐个字符读取文件

逐个字符读取文件:

  1. 以读模式打开文件。
  2. 使用 for 循环遍历文件。
  3. 使用嵌套的 for 循环遍历每一行。
  4. 嵌套的 for 循环将逐字符读取文件。
with open('example.txt', 'r', encoding='utf-8') as file:
    for line in file:
        for char in line:
            print(char)

代码示例假定我们在同一目录中有一个 example.txt 文件。

第一个示例中的 while 循环没有这个问题。