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格式的,是无效的,因为那个是改的写代码格式,而不是你写入脚本的格式。改这里只会改变你写代码的格式