本文介紹基於Python語言,遍歷資料夾並從中找到檔名稱符合我們需求的多個.txt
格式文字檔案,並從上述每一個文字檔案中,找到我們需要的指定資料,最後得到所有文字檔案中我們需要的資料的合集的方法。
首先,我們來明確一下本文的具體需求。現有一個資料夾,其中含有大量的.txt
格式文字檔案,如下圖所示;同時,這些文字檔案中,檔名中含有Point
欄位的,都是我們需要的檔案,我們接下來的操作都是對這些我們需要的檔案而言的;而不含有Point
這個欄位的,那麼我們就不需要。
隨後,在每一個我們需要的文字檔案(也就是檔名中含有Point
欄位的檔案)中,都具有著如下圖所示的資料格式。我們希望,基於第1
列(紅色框內所示的列)資料(這一列資料表示波長),找到幾個指定波長資料所對應的行,並將這些行所對應的後5
列資料都儲存下來。
此外,前面也提到,檔名中含有Point
欄位的文字檔案是有多個的;因此希望將所有文字檔案中,符合要求的資料行都儲存在一個變數,且儲存的時候也將檔名稱儲存下來,從而知道儲存的每一行資料,具體是來自於哪一個檔案。
知道了需求,我們就可以開始程式碼的書寫。其中,本文用到的具體程式碼如下所示。
# -*- coding: utf-8 -*-
"""
Created on Fri Jul 7 23:39:43 2023
@author: fkxxgis
"""
import os
import pandas as pd
original_file_folder = "E:/03_Experiment/202306HuaiLai/HuaiLai_20230627_SpectralCurve"
result_file_path = "E:/03_Experiment/202306HuaiLai/HuaiLai_20230627_SpectralCurve/Result.csv"
target_wavelength = [490, 561, 665, 702, 863]
result_all_df = pd.DataFrame()
for file in os.listdir(original_file_folder):
if file.endswith(".txt") and file[3] == "P":
file_path = os.path.join(original_file_folder, file)
df = pd.read_csv(file_path, delimiter = "\t")
select_df = df[df["Wavelength"].isin(target_wavelength)]
select_df.insert(0, "file_name", file)
data_append = select_df.iloc[1 : , 2 : ]
result_df = pd.DataFrame()
result_df = pd.concat([select_df.iloc[[0]].reset_index(drop = True), pd.DataFrame(data_append.values.flatten()).transpose()], axis = 1)
result_df.columns = range(result_df.shape[1])
result_all_df = pd.concat([result_all_df, result_df], axis = 0, ignore_index = True)
上述程式碼具體的含義如下所示。
首先,我們匯入了需要使用的庫——os
庫用於檔案操作,而pandas
庫則用於資料處理;接下來,我們定義了原始資料夾路徑 original_file_folder
和結果檔案路徑 result_file_path
。然後,我們建立一個空的DataFrame物件result_all_df
,用於儲存所有處理後的結果。
再接下來,透過使用os.listdir()
函式,我們遍歷指定資料夾中的檔案。我們透過條件過濾,只選擇以.txt
結尾且檔名的第四個字母是P
的檔案——這些檔案就是我們需要的檔案。隨後,對於每個滿足條件的檔案,我們構建了檔案的完整路徑file_path
,並使用pd.read_csv()
函式讀取檔案的內容。在這裡,我們使用製表符作為分隔符,並將資料儲存在DataFrame物件df
中。
然後,我們根據給定的目標波長列表target_wavelength
,使用條件篩選出包含目標波長的資料行,並將檔名插入到選定的DataFrame中,即在第一列插入名為file_name
的列——這一列用於儲存我們的檔名。
接下來,在我們已經提取出來的資料中,從第二行開始,提取每一行從第三列到最後一列的資料,將其展平為一維陣列,從而方便接下來將其放在原本第一行的後面(右側)。然後,我們使用pd.DataFrame()
函式將展平的陣列轉換為DataFrame物件;緊接著,我們使用pd.concat()
函式將原本的第一行資料,和展平後的資料按列合併(也就是放在了第一行的右側),並將結果儲存在result_df
中。
最後,我們將每個檔案的處理結果按行合併到result_all_df
中,透過使用pd.concat()
函式,指定axis=0
表示按行合併。由於我這裡的需求是,只要保證文字檔案中的資料被提取到一個變數中就夠了,所以沒有將結果儲存為一個獨立的檔案。如果需要儲存為獨立的.csv
格式檔案,大家可以參考文章多次複製Excel符合要求的資料行:Python批次實現。
執行上述程式碼,即可看到儲存我們提取出來的資料的結果的變數result_all_df
的具體情況如下圖所示。可以看到,已經儲存了我們提取出來的具體資料,以及資料具體來原始檔的檔名稱;並且從一個文字檔案中提取出來的資料,都是儲存在一行中,方便我們後期的進一步處理。
至此,大功告成。