关于文件写入与读取的几个问题

1.如何将数组型内容写入1.txt

        for xieruneirong in yuanshineirong:    # 逐一读取yuanshineirong数组,获得数组每一个值
            with open(f'1.txt', mode ='a') as f:    # 打开1.txt文件,注意文件路径
                f.write(xieruneirong + '\n')    # \n换行,避免写入的东西连在一起

 mode代表操作类型,可以选择的类型有:

r:   以只读方式打开文件。文件的指针将会放在文件的开头。这是**默认模式**。
rb:  以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。
r+:  打开一个文件用于读写。文件指针将会放在文件的开头。
rb+: 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
w:   打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
wb:  以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
w+:  打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
wb+: 以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a:   打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
ab:  以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
a+:  打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
ab+: 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。

f.write代表将字符串写入文件,其他类型有:

file.read([size])        #将文件数据作为字符串返回,可选参数size控制读取的字节数

file.readlines([size])   #返回文件中行内容的列表,size参数可选

file.write(str)          #将字符串写入文件

file.writelines(strings) #将字符串序列写入文件

file.close()             #关闭文件

file.closed                 #表示文件已经被关闭,否则为False

file.mode                 #Access文件打开时使用的访问模式

file.encoding             #文件所使用的编码

file.name                 #文件名

file.newlines             #未读取到行分隔符时为None,只有一种行分隔符时为一个字符串,当文件有多种类型的行结束符时,则为一个包含所有当前所遇到的行结束的列表

file.softspace             #为0表示在输出一数据后,要加上一个空格符,1表示不加。这个属性一般程序员用不着,由程序内部使用

关于write和open有一个小差别

当文件不存在的时候,write并不会报错,它会新建一个文件夹;但是如果是open,则会直接提示FileNotFoundError: [Errno 2] No such file or directory

———————————————————————————————————————————

Python里处理.sh脚本,脚本上传到Linux后不能正常运行,提示未预期的符号'\r'附近有语法错误

原问题及代码

Python 更改sh脚本,上传到Linux后不能正常运行-编程语言-CSDN问答

原因:\n在Windows里是正常识别,但是到了Linux会被识别成\r\n,所以即使脚本里看不到\r这个字符,到Linux里也会报错,

解决方案:用二进制写内容和换行

参考代码:

    with open(localpath, 'rb') as wenjian:
        duqu = wenjian.read()
        h = duqu.split(b'\n')    # 打开文件并读取每一行
        h[7] = b''
        h[8] = b''                # 7,8行改成空行
        h[9] = b'case 1 in'        # 9行内容改为 casse 1 in
        new_duqu = b'\n'.join(h)    # 在行结尾添加二进制型换行
    with open(localpath, 'wb') as wenjian:
        wenjian.write(new_duqu)    # 将内容重新写入文件

有部分博主说把pycharm右下角行分隔符换成LF格式的,是无效的,因为那个是改的写代码格式,而不是你写入脚本的格式。改这里只会改变你写代码的格式

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值