第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

遍歷目錄中的所有文件并從每個(gè)文件中獲取平均值

遍歷目錄中的所有文件并從每個(gè)文件中獲取平均值

臨摹微笑 2022-06-22 17:38:14
我在一個(gè)目錄中有幾個(gè)文件,我想將所有文件第一列中第一個(gè)和最后一個(gè)數(shù)字的平均值打印到一個(gè)文件中。請(qǐng)問該怎么做?此代碼不完整:# giving names of all files in a directory to the file files.txt - OKimport osfiles = os.listdir("/media/linux/DATADISK")with open('files.txt', 'w') as f:    for item in files:        f.write("%s\n" % item)# loading the first column of all files into lists or dataframes with the name/key according files.txt and save average value to file average.txtfor i in files:    np.loadtext(f'   .  ', unpack=True, usecols=[0]))    average = (list[0]+list[-1])/2    print(average, , file=open("average.txt","a"))我不知道如何編寫for應(yīng)該加載文件的第二個(gè)循環(huán)(第一列),計(jì)算最后一個(gè)值和第一個(gè)值的平均值,并將其寫入文件。它應(yīng)該對(duì)目錄中的所有文件執(zhí)行此操作。我不知道如何寫文件名——它們有不同的名稱和相同的擴(kuò)展名。例如,目錄中有 2 個(gè)文件:klj.txt 和 gdf.datklj.txt4 6 6 5  6 1gdf.dat4 52 08 1輸出 average.txt 應(yīng)該是:5 6
查看完整描述

1 回答

?
莫回?zé)o

TA貢獻(xiàn)1865條經(jīng)驗(yàn) 獲得超7個(gè)贊

首先,您不需要將文件寫入files.txt的單獨(dú)循環(huán)。您可以將整個(gè)操作作為os.listdir循環(huán)的一部分進(jìn)行。您只需要形成每個(gè)文件的完整路徑(np.loadtxt稍后需要傳遞的路徑)。像這樣:


import os

data_path = os.path.abspath("/media/linux/DATADISK")


for f in os.listdir(data_path):

    f_path = os.path.join(data_path, f)

    print(f_path)


# Output:

# /media/linux/DATADISK/gdf.dat

# /media/linux/DATADISK/klj.txt

然后,您可以使用delimiter參數(shù) ofnp.loadtxt指定每個(gè)文件的每一行用空格分隔。如果您只對(duì)第一列感興趣,您輸入的usecols參數(shù)已經(jīng)正確。


data = np.loadtxt(f_path, delimiter=' ', usecols=0)

print(data)


# Output:

# /media/linux/DATADISK/gdf.dat

# [4. 2. 8.]

# /media/linux/DATADISK/klj.txt

# [4. 6. 6.]

那么你已經(jīng)把代碼的平均部分正確了。但我建議先打開average.txt文件,這樣您就不需要open在每個(gè)循環(huán)中都打開它。


with open("average.txt", "a") as output:

    for f in os.listdir(data_path):

        ...

        average = (data[0] + data[-1]) / 2

        output.write(str(average) + "\n")

把它們放在一起:


import numpy as np

import os

data_path = os.path.abspath("/media/linux/DATADISK")


with open("average.txt", "a") as output:

    for f in os.listdir(data_path):

        f_path = os.path.join(data_path, f)

        data = np.loadtxt(f_path, delimiter=' ', usecols=0)

        average = (data[0] + data[-1]) / 2

        output.write(str(average) + "\n")

樣本平均.txt:


6.0

5.0

訂單將取決于 的返回os.listdir,因此gdf.bat將在klj.txt之前處理。


查看完整回答
反對(duì) 回復(fù) 2022-06-22
  • 1 回答
  • 0 關(guān)注
  • 193 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)