python如何将文本文件读入列表_如何使用Python将文本文件读入列表或数组

所以你想创建一个列表列表......我们需要从一个空列表开始

list_of_lists = []

接下来,我们逐行阅读文件内容

with open('data') as f:

for line in f:

inner_list = [elt.strip() for elt in line.split(',')]

# in alternative, if you need to use the file content as numbers

# inner_list = [int(elt.strip()) for elt in line.split(',')]

list_of_lists.append(inner_list)

一个常见的用例是柱状数据,但我们的存储单元是文件的行,我们已逐一阅读,因此您可能想要转置列表列表 . 这可以通过以下习语来完成

by_cols = zip(*list_of_lists)

另一个常见用途是为每列提供一个名称

col_names = ('apples sold', 'pears sold', 'apples revenue', 'pears revenue')

by_names = {}

for i, col_name in enumerate(col_names):

by_names[col_name] = by_cols[i]

这样您就可以对同类数据项进行操作

mean_apple_prices = [money/fruits for money, fruits in

zip(by_names['apples revenue'], by_names['apples_sold'])]

我写的大部分内容都可以使用标准库中的 csv 模块加速 . 另一个第三方模块是 pandas ,它允许您自动化典型数据分析的大多数方面(但具有许多依赖性) .

更新在Python 2中 zip(*list_of_lists) 返回一个不同的(转置的)列表列表,在Python 3中情况发生了变化, zip(*list_of_lists) 返回了一个不可订阅的zip对象 .

如果您需要索引访问,则可以使用

by_cols = list(zip(*list_of_lists))

它为您提供了两个版本的Python列表 .

另一方面,如果你不需要索引访问,你想要的只是 Build 一个由列名索引的字典,一个zip对象就好了......

file = open('some_data.csv')

names = get_names(next(file))

columns = zip(*((x.strip() for x in line.split(',')) for line in file)))

d = {}

for name, column in zip(names, columns): d[name] = column

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值