python逐行输出_python逐行输出

本文详细介绍了Python中如何对文本文件进行逐行读写操作,包括打开、读取、关闭文件的步骤,以及读取txt文件的常用方法,如`readline()`、`readlines()`等。同时讲解了文件的不同打开模式,如追加、覆盖等,并给出了内容查找和替换的实例。最后,提供了一个读取文件、去除空行和注释行并排序的脚本示例。
摘要由CSDN通过智能技术生成

一、文件的打开和创建

?

12345

f = open('/tmp/test.txt')f.read()'hello python!nhello world!n'f

二、文件的读取步骤:打开 -- 读取 -- 关闭

?

1234

f = open('/tmp/test.txt')f.read()

'hello python!nhello world!n'

f.close()

读取数据是后期数据处理的必要步骤。.txt是广泛使用的数据文件格式。一些.csv, .xlsx等文件可以转换为.txt 文件进行读取。我常使用的是Python自带的I/O接口,将数据读取进来存放在list中,然后再用numpy科学计算包将list的数据转换为array格式,从而可以像MATLAB一样进行科学计算。

下面是一段常用的读取txt文件代码,可以用在大多数的txt文件读取中

?

12345678910111213141516

filename = 'array_reflection_2D_TM_vertical_normE_center.txt' # txt文件和当前脚本在同一目录下,所以不用写具体路径pos = []Efield = []with open(filename, 'r') as file_to_read: while True:

lines = file_to_read.readline() # 整行读取数据

if not lines:

break

pass

p_tmp, E_tmp = [float(i) for i in lines.split()] # 将整行数据分割处理,如果分割符是空格,括号里就不用传入参数,如果是逗号, 则传入‘,'字符。

pos.append(p_tmp) # 添加新读取的数据

Efield.append(E_tmp)

pass

pos = np.array(pos) # 将数据从list类型转换为array类型。 Efield = np.array(Efield) pass

例如下面是将要读入的txt文件

2016626171647895.png (429×301)

经过读取后,在Enthought Canopy的variable window查看读入的数据, 左侧为pos,右侧为Efield。

2016626171713978.png (148×277)2016626171743777.png (147×280)

三、文件写入(慎重,小心别清空原本的文件)步骤:打开 -- 写入 -- (保存)关闭 直接的写入数据是不行的,因为默认打开的是'r' 只读模式

?

123456

f.write('hello boy')Traceback (most recent call last):

File "", line 1, in IOError: File not open for writing

f

应该先指定可写的模式

?

12

f1 = open('/tmp/test.txt','w')f1.write('hello boy!')</

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值