→ PTT007: 不只0和1,還會有23456...等 10/10 00:45
那就多設幾個 result23456...,下面多幾個 elif 啊!
不過還有更簡單的。
先把上面的 result1, result2 改成
result = [0] * 10
下面的 while loop 改成
while s != ''
result[int(s[0])] += float(s)
s = txt.readline()
唔,這樣比原來還更簡潔耶。
※ 編輯: wohtp (123.110.141.102), 10/10/2014 00:58:33
※ 編輯: wohtp (123.110.141.102), 10/10/2014 01:00:54
→ PTT007: 可能會有上百個,不可能設這麼多elif吧QQ 10/10 01:16
→ PTT007: 下面那方法我再看一下 感謝~ 10/10 01:20
你只說 0 和 1,我就只分 0 和 1;你只說有23456...,我就只分個位數。
不講清楚誰知道你需要什麼 -_-
※ 編輯: wohtp (123.110.141.102), 10/10/2014 01:28:17
→ PTT007: 呃 我後面不是有打....嗎 就表示那會延伸下去阿 =.= 10/10 01:29
→ PTT007: 另一個方法剛試了OK~感謝您~ 10/10 01:33
→ bigpigbigpig: 那就用 split() 啊,第一個元素當做 dict 的 key 10/10 12:06
推 goodseeyou: 這個方法比較好 10/11 00:57
→ goodseeyou: 雖然需要知道值域範圍 跟有可能浪費 memory 但應不是 10/11 01:00
→ goodseeyou: 問題 10/11 01:00
用dict不需要知道值域範圍吧,看到幾個加幾個key進去就是了。
以下是大豬大豬大的建議:
result = {} # 空的 dict
s = txt.readline()
while s != '':
intPart = s.split(',')[0] # 把整數部分拉出來
if intPart in result: # 測看看是否已經有這一項了
result[intPart] += float(s) # 有就直接加在一起
else:
result[intPart] = float(s) # 沒有的話要多添這項
s = text.readline()
只有 0 和 1 有只有 0 和 1 的寫法,只有個位數有只有個位數的寫法,
中間不跳號有中間不跳號的寫法,資料有沒有排序也當然有差。
現在這個是最一般,什麼(abcd.wxyz)這種形式丟進去都能處理的程式。
可是也必然比較大比較慢。
※ 編輯: wohtp (123.110.141.102), 10/11/2014 01:33:30
※ 編輯: wohtp (123.110.141.102), 10/11/2014 01:33:49
※ 編輯: wohtp (123.110.141.102), 10/11/2014 01:34:54
推 ckclark: split應該是. 另外result = defaultdict(float)更方便 10/11 02:25