亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 24634975 | 回復(fù): 24634975
打印 上一主題 下一主題

python對(duì)文本文檔的求和平均 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2012-01-12 12:23 |只看該作者 |倒序?yàn)g覽
如下列這個(gè)數(shù)據(jù)文檔
   ci    pi       er          cc     22         ii
    2      3        5          1        2        4
    2       4      5           5       1         4
    5       6       6          5       6         7
    7       7       5          4       3         1
怎么讓  cc列的數(shù)據(jù)  求和平均

論壇徽章:
0
2 [報(bào)告]
發(fā)表于 2012-01-12 13:05 |只看該作者
你的問題說得不是很清楚,如果是要讓CC列為其他各列的平均值的話可以這樣
  1. dfile = open(r'd:\test.txt', 'r')
  2. result = []
  3. titles = dfile.readline().split()
  4. result.append(titles)
  5. index = titles.index('cc')
  6. for line in dfile:
  7.     data = line.split()
  8.     avg = (sum([float(i) for i in data]) - float(data[index])) / (len(data) - 1)
  9.     data[index] = avg
  10.     result.append(data)

  11. for index, data in enumerate(result):
  12.     result[index] = ''.join(['%8s' % s for s in data])
  13.    
  14. dfile.close()
  15. dfile = open(r'd:\test.txt', 'w')
  16. dfile.write('\n'.join(result))
  17. dfile.close()
復(fù)制代碼

論壇徽章:
0
3 [報(bào)告]
發(fā)表于 2012-01-12 13:14 |只看該作者
我明白你的意思了
       不過我要的是 單純  cc這一列的所有值求和  至于求不求平均倒也無所謂
        在這個(gè)數(shù)據(jù)文檔里面  即是要[1,5,5,4]4個(gè)值迭加

論壇徽章:
0
4 [報(bào)告]
發(fā)表于 2012-01-12 13:17 |只看該作者
  整個(gè)過程是這樣  通過在數(shù)據(jù)庫中抓取數(shù)據(jù)(通過快照,每隔一段時(shí)間抓去然后記錄)  建立如上面類似的數(shù)據(jù)文檔   挑選想要的一些數(shù)據(jù)計(jì)算平均值。 比如cc的平均值,ci的平均值

論壇徽章:
0
5 [報(bào)告]
發(fā)表于 2012-01-12 13:49 |只看該作者
本帖最后由 inpool 于 2012-01-12 13:53 編輯

那就更簡(jiǎn)單了
  1. def get_avg(path, colname):
  2.     dfile = open(path)
  3.     index = dfile.readline().split().index(colname)
  4.     data = [float(line.split()[index]) for line in dfile]
  5.     dfile.close()
  6.     return sum(data)/len(data)

  7. if __name__ == '__main__':
  8.     avg = get_avg(r'd:\test.txt', 'cc')
  9.     print avg
復(fù)制代碼

論壇徽章:
0
6 [報(bào)告]
發(fā)表于 2012-01-12 14:55 |只看該作者
樓上厲害啊

論壇徽章:
0
7 [報(bào)告]
發(fā)表于 2012-01-12 15:18 |只看該作者
f = file('file.txt')
s = []
sum = 0
for lines in f:
    s.append(lines.split())
index = s[0].index('cc')
for i in s[1:]:
    sum = sum + int(i[index])
print "The sum of the colum 'cc' is %d"%sum
print "The average of the colum 'cc' is %d"%(sum/(len(s)-1))



論壇徽章:
0
8 [報(bào)告]
發(fā)表于 2012-01-12 17:07 |只看該作者
本帖最后由 houwenhui1990 于 2012-01-12 17:22 編輯
  1. #!/usr/bin/env python
  2. f=open('a.txt','r')
  3. title=f.readline().split()
  4. index=title.index('cc')
  5. sum=0
  6. num=0
  7. while True:
  8.     line=f.readline().split()
  9.     if bool(line)!=0:
  10.         sum+=int(line[index])
  11.         num+=1
  12.     else:
  13.         f.close()
  14.         print 'sum is %d, avg is %.2f'%(sum,float(sum)/num)
  15.         break
復(fù)制代碼

論壇徽章:
0
9 [報(bào)告]
發(fā)表于 2012-07-21 16:47 |只看該作者
inpool 發(fā)表于 2012-01-12 13:49
那就更簡(jiǎn)單了

第4行不會(huì)把第一行讀到嗎?

論壇徽章:
0
10 [報(bào)告]
發(fā)表于 2012-07-21 17:58 |只看該作者
本帖最后由 nmweizi 于 2012-07-21 18:26 編輯

from __future__ import division
from pandas import *
df= read_csv(r'F:\python\pandas\test1.txt',sep ='[ ]*',index_col=None)
f = df['cc']
f.sum()/f.count()

或者
print  df.sum()/df.count()


Out[10]:
ci    4.00
pi    5.00
er    5.25
cc    3.75
22    3.00
ii    4.00
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國(guó)互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP