如何使用Python只获取文件的第一行作为字符串?
使用.readline()方法:
with open('myfile.txt') as f:
first_line = f.readline()
注意,除非它是文件中唯一的一行,否则f.r edline()返回的字符串将包含一个尾随换行符。你可能希望使用
with open('myfile.txt') as f:
first_line = f.readline().strip('\n')
而是删除换行符。
这里有很多其他的答案,但准确地回答你问的问题(在@MarkAmery编辑了原始问题并改变了意思之前):
>>> f = open('myfile.txt')
>>> data = f.read()
>>> # I'm assuming you had the above before asking the question
>>> first_line = data.split('\n', 1)[0]
换句话说,如果您已经读取了文件(如您所说),并且内存中有一大块数据,那么为了有效地从其中获取第一行,只需对换行符执行split(),并从结果列表中获取第一个元素。
注意,这并不包括行末的\n字符,但我假设您根本不需要它(单行文件甚至可能没有)。还要注意的是,尽管它非常简短和快速,但它确实复制了数据,所以对于一个非常大的内存块,您可能不会认为它是“有效的”。一如既往,这取决于……
如果你想读取file。txt
line1 helloworld
import linecache
# read first line
print(linecache.getline('file.txt'), 1)
>helloworld
推荐文章
- 将Pandas或Numpy Nan替换为None以用于MysqlDB
- 使用pandas对同一列进行多个聚合
- 使用Python解析HTML
- django MultiValueDictKeyError错误,我如何处理它
- 如何在for循环期间修改列表条目?
- 我如何在Django中创建一个鼻涕虫?
- 没有名为'django.core.urlresolvers'的模块
- 蟒蛇导出环境文件
- Django - makemigrations -未检测到任何更改
- SQLAlchemy:引擎、连接和会话差异
- 在Python Pandas中删除多个列中的所有重复行
- 更改pandas DataFrame中的特定列名
- 将Pandas多索引转换为列
- 熊猫在每组中获得最高的n个记录
- 熊猫数据帧得到每组的第一行