python可以同时对文件进行读写 *** 作吗

python可以同时对文件进行读写 *** 作吗,第1张

文件的 *** 作,步骤为:打开一个文件-->读取/写入内容-->保存文件

文件读写的3中模式

# 1、w 写模式,它是不能读的,如果用w模式打开一个已经存在的文件,会清空以前的文件内容,重新写

#w+ 是读写内容,只要沾上w,肯定会清空原来的文件

# 2、r 读模式,只能读,不能写,而且文件必须存在

#r+ 是读写模式,只要沾上r,文件必须存在

# 3、a 追加模式,也能写,在文件的末尾添加内容

# 4、rb+、wb+、ab+,这种是二进制模式打开或者读取,一些音乐文件

test1.txt

1 如果无情的风摘走了那片树叶

2 如同摘走了我的心

3 在每一个想你的夜晚

4 请允许我将你抱紧

5 我不像一只大雁可以秋去春来

6 衔回丢失的缘分

7 所以从来不敢回忆离别

8 越是清晰 越是伤心

9 你说所有的城市没有不同

10 我宁愿相信你心中有片草原

1、循环读取文件中的每一行内容:

demo1.py1 file = open('test1.txt','r+')# 打开test1.txt 文件

2 for line in file: # 遍历file文件

3 print('line里面存放的是:',line) # 循环打印文件中每一行内容

4 print(type(line)) # <class 'str'>类型是字符串

5 file.close()# 关闭文件

用with的方式打开文件,不用担心使用完文件后忘记关闭,它会自动将文件关闭1 with open('test1.txt','r+') as file:

2 for line in file:

3 print('line里面存放的是:',line) # 循环打印文件中每一行内容

4 print(type(line)) # <class 'str'>类型是字符串

3、向文件中写入内容

1 with open('users','a+') as fw: # 打开文件

2 fw.write('写入文件内容')

4、用函数的方式读取文件

1 def read_file(filename):

2 '''

3 用来读取文件内容

4 :param filename: 文件名

5 '''

6 with open(filename,'a+') as fr:

7 fr.seek(0) # 移动文件指针

8 content = fr.read() # content 类型是字符串

9 print('content:',content)

10 read_file('users') # 调用函数

5、用函数的方式写文件

1 def write_file(filename,content):

2 '''

3 用来读取文件内容的

4 :param filename: 文件名

5 '''

6 with open(filename,'a+') as fw:

7 fw.seek(0) # 移动文件指针

8 fw.truncate() # 清空文件内容

9 fw.write(str(content))

10 write_file('a','hello world') # 调用函数

读文件

    1)使用open()方法打开文件,返回一个文件对象

        原型:open(file, mode='r', buffering=None, encoding=None, errors=None, newline=None, closefd=True)

        举例:f = open('test.txt', 'r')

        test.txt表示文件路径(包含文件名,这个file参数可以是绝对或者相对路径)

        r表示是读文本文件,rb是读二进制文本文件。(这个mode参数默认值就是r)

    2)使用close()方法关闭文件

        f.close()

        打开后的文件必须关闭,因为文件对象会占用系统资源,系统打开文件数量也就有限了

    3)打开文件时的异常处理

        f=open('test.txt', 'r')

        f.read()

        f.close()

        FileNotFoundError: [Errno 2] No such file or directory: 'test.txt'

        文件读写时都有可能产生异常IOError(比如文件不存在),这样其后面的f.read(),f.close()就不会调用。为保证无论是否异常都可以关闭文件,一般使用try ... finally来处理:

        try:

            f = open('test.txt', 'r')

            f.read()

        finally:

            if f:

                f.close()

        但这种写法过于繁琐,所以Python引入了with语句来自动调用close()方法:

        with open('test.txt', 'r') as f:

            f.read()

    4)读文件 - read()、readline() 和 readlines()

        read() 一次读取整个文件,它通常用于将文件内容放到一个字符串变量中。如果文件过大,内存不够,可以通过反复调用read(size)方法,每次最多读取size个字节的内容。

        readline() 一次读取文件中一行内容,可反复调用

        readlines() 一次读取所有内容并按行返回列表,该列表可以由for ... in ... 结构再进一步处理。

        特别注意:

        这三种方法是把每行末尾的'\n'也读进来了,如有需要就得我们手动去掉'\n'

        with open('test.txt', 'r') as f:

            list = f.readlines()

        for i in range(0, len(list)):

            list[i] = list[i].rstrip('\n')

写文件

    1)写文件和读文件是一样的,唯一区别是open文件时,传入标识符不同,即'w'或者'wb'表示写文本文件或写二进制文件

    f = open('test.txt', 'w')

    f = open('test.txt', 'wb')

    f = open('test.txt', 'a')

    f.close()

    特别注意:

    1. 如果没有这个文件,会自动创建一个新文件;如果有,就会先把原文件的内容清空再写入;若不想清空原来的内容而是直接在后面追加新的内容,就用'a'这个模式

    2. 写文件, *** 作系统往往不会立刻把数据写入磁盘,而是放到内存缓存起来,空闲的时候再慢慢写入。只有调用close()方法时, *** 作系统才保证把没有写入的数据全部写入磁盘。忘记调用close()的后果是数据可能只写了一部分到磁盘,剩下的丢失了。

    2)写文件 - write()、writelines()

    write()方法和read()、readline()方法对应,是将字符串写入到文件中。

    writelines()方法和readlines()方法对应,也是针对 列表 的 *** 作。它接收一个 字符串列表 作为参数,将他们写入到文件中。

    特别注意:

    换行符不会自动的加入,需要显式的加入换行符。

    f = open('test.txt', 'w')

    f.writelines(["111\n", "222\n", "333\n"])

补充说明:

1)对于非默认编码(utf-8)的文件,需要open时添加encording参数,选择对应的编码方式

2)r+, w+, a+,可读可写

3)seek()方法,移动文件指针

seek(offset[, whence]) ,offset是相对于某个位置的偏移量。位置由whence决定,默认whence=0,从开头起;whence=1,从当前位置算起;whence=2相对于文件末尾移动,通常offset取负值。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12012256.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存