Re: [问题] txt内容切割加总

楼主: wohtp (会喵喵叫的大叔)   2014-10-10 00:37:40
※ 引述《PTT007 (优质单身好男人)》之铭言:
: 如果我有一个txt内容如下:
: 0.01
: 0.02
: 0.03
: 0.09
: 1.03
: 1.02
: 1.01
: 我想将 0.X 和 1.X 各自累加起来
: 输出结果为 0.15 和 3.06
: 我目前的做法是
: number_of_line = len(txt) # txt总共几行
: result = 0
: for i in range(2):
: for j in range(number_of_line):
: if i == int(current_row_value):
: result += current_row_value
: print result
: result = 0
: 但我这样写,资料量多的话就会跑很久
: 请问有其他较好的方法吗
: 谢谢
txt = open("input.txt")
s = txt.readline() # 先读一行进来
result1 = 0 # 一次就可以做完,loop两次干嘛?
result2 = 0
while s != '': # 检查档案尾
if s[0] == '0': # 如果你很确定只有 0 和 1 需要分开的话...
result1 += float(s)
else:
result2 += float(s)
s = txt.readline() # 进下一行
print(result1, result2)
作者: PTT007 ( )   2014-10-10 00:45:00
不只0和1,还会有23456...等可能会有上百个,不可能设这么多elif吧QQ下面那方法我再看一下 感谢~呃 我后面不是有打....吗 就表示那会延伸下去阿 =.=另一个方法刚试了OK~感谢您~
作者: bigpigbigpig (To littlepig with love)   2014-10-10 12:06:00
那就用 split() 啊,第一个元素当做 dict 的 key
作者: goodseeyou (好看你)   2014-10-11 00:57:00
这个方法比较好虽然需要知道值域范围 跟有可能浪费 memory 但应不是问题
作者: ckclark (大资佬)   2014-10-11 02:25:00
split应该是. 另外result = defaultdict(float)更方便

Links booklink

Contact Us: admin [ a t ] ucptt.com