真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

讀取、創(chuàng)建和運行多個文件的Python技巧有哪些

本篇內(nèi)容介紹了“讀取、創(chuàng)建和運行多個文件的Python技巧有哪些”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

創(chuàng)新互聯(lián)建站專注于遵義網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供遵義營銷型網(wǎng)站建設(shè),遵義網(wǎng)站制作、遵義網(wǎng)頁設(shè)計、遵義網(wǎng)站官網(wǎng)定制、微信小程序服務(wù),打造遵義網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供遵義網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。

動機

將代碼投入生產(chǎn)時,你很可能需要處理代碼文件的組織。讀取、創(chuàng)建和運行許多數(shù)據(jù)文件非常耗時。本文將向你展示如何自動

  • 循環(huán)訪問目錄中的文件

  • 如果不存在嵌套文件,創(chuàng)建它們

  • 使用bash for loop運行一個具有不同輸入的文件

這些技巧為我在數(shù)據(jù)科學(xué)項目中節(jié)省了很多時間。我希望你也會發(fā)現(xiàn)它們有用!

循環(huán)訪問目錄中的文件

如果我們要像這樣讀取和處理多個數(shù)據(jù):

├── data │   ├── data1.csv │   ├── data2.csv │   └── data3.csv └── main.py

我們可以嘗試一次手動讀取一個文件

import pandas as pd   def process_data(df):    pass  df = pd.read_csv(data1.csv) process_data(df)  df2 = pd.read_csv(data2.csv) process_data(df2)  df3 = pd.read_csv(data3.csv) process_data(df3)

當(dāng)我們有3個以上的數(shù)據(jù)時,這是可以的,但不是有效的。如果我們在上面的腳本中只更改了數(shù)據(jù),為什么不使用for循環(huán)來訪問每個數(shù)據(jù)呢?

下面的腳本允許我們遍歷指定目錄中的文件

import os import pandas as pd def loop_directory(directory: str):     '''循環(huán)目錄中的文件'''      for filename in os.listdir(directory):         if filename.endswith(".csv"):             file_directory = os.path.join(directory, filename)             print(file_directory)             pd.read_csv(file_directory)         else:             continue  if __name__=='__main__':     loop_directory('data/')
data/data3.csv data/data2.csv data/data1.csv

以下是對上述腳本的解釋

  • for filename in os.listdir(directory):循環(huán)訪問特定目錄中的文件

  • if filename.endswith(".csv"):訪問以“.csv”結(jié)尾的文件

  • file_directory = os.path.join(directory, filename):連接父目錄('data')和目錄中的文件。

現(xiàn)在我們可以訪問“data”目錄中的所有文件!

如果不存在嵌套文件,創(chuàng)建它們

有時,我們可能希望創(chuàng)建嵌套文件來組織代碼或模型,這使得將來更容易找到它們。例如,我們可以使用“model 1”來指定特定的特征工程。

在使用模型1時,我們可能需要使用不同類型的機器學(xué)習(xí)模型來訓(xùn)練我們的數(shù)據(jù)(“model1/XGBoost”)。

在使用每個機器學(xué)習(xí)模型時,我們甚至可能希望保存模型的不同版本,因為模型使用的超參數(shù)不同。

因此,我們的模型目錄看起來像下面這樣復(fù)雜

model ├── model1 │   ├── NaiveBayes │   └── XGBoost │       ├── version_1 │       └── version_2 └── model2     ├── NaiveBayes     └── XGBoost         ├── version_1         └── version_2

對于我們創(chuàng)建的每個模型,手動創(chuàng)建一個嵌套文件可能需要很多時間。有沒有辦法讓這個過程自動化?是的,os.makedirs(datapath)。

def create_path_if_not_exists(datapath):     '''如果不存在,則創(chuàng)建新文件并保存數(shù)據(jù)'''      if not os.path.exists(datapath):         os.makedirs(datapath)   if __name__=='__main__': create_path_if_not_exists('model/model1/XGBoost/version_1')

運行上面的文件,你應(yīng)該會看到嵌套文件'model/model2/XGBoost/version_2'自動創(chuàng)建!

現(xiàn)在你可以將模型或數(shù)據(jù)保存到新目錄中!

import joblib import os   def create_path_if_not_exists(datapath):     '''如果不存在就創(chuàng)建'''      if not os.path.exists(datapath):         os.makedirs(datapath)   if __name__=='__main__':    # 創(chuàng)建目錄   model_path = 'model/model2/XGBoost/version_2'   create_path_if_not_exists(model_path)    # 保存   joblib.dump(model, model_path)

Bash for Loop:使用不同的參數(shù)運行一個文件

如果我們想用不同的參數(shù)運行一個文件呢?例如,我們可能希望使用相同的腳本來使用不同的模型來預(yù)測數(shù)據(jù)。

import joblib  # df = ...  model_path = 'model/model1/XGBoost/version_1' model = joblib.load(model_path) model.predict(df)

如果一個腳本需要很長時間才能運行,而我們有多個模型要運行,那么等待腳本運行完畢然后運行下一個腳本將非常耗時。有沒有一種方法可以告訴計算機用一個命令行運行1,2,3,10,然后去做其他的事情。

是的,我們可以用for bash for  loop。首先,我們使用系統(tǒng)argv使我們能夠解析命令行參數(shù)。如果要覆蓋命令行上的配置文件,也可以使用hydra等工具。

import sys import joblib  # df = ...  model_type = sys.argv[1] model_version = sys.argv[2] model_path = f'''model/model1/{model_type}/version_{model_version}''' print('Loading model from', model_path, 'for training')  model = joblib.load(model_path) mode.predict(df)
>>> python train.py XGBoost 1 Loading model from model/model1/XGBoost/version_1 for training

太好了!我們剛剛告訴我們的腳本使用模型XGBoost,version 1來預(yù)測命令行上的數(shù)據(jù)?,F(xiàn)在我們可以使用bash循環(huán)遍歷模型的不同版本。

如果你可以使用Python執(zhí)行for循環(huán),那么也可以在下面這樣的終端上執(zhí)行

$ for version in 2 3 4 > do > python train.py XGBoost $version > done

鍵入Enter分隔行

輸出:

Loading model from model/model1/XGBoost/version_1 for training Loading model from model/model1/XGBoost/version_2 for training Loading model from model/model1/XGBoost/version_3 for training Loading model from model/model1/XGBoost/version_4 for training

現(xiàn)在,你可以在使用不同模型運行腳本的同時執(zhí)行其他操作!多方便啊!

“讀取、創(chuàng)建和運行多個文件的Python技巧有哪些”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!


文章名稱:讀取、創(chuàng)建和運行多個文件的Python技巧有哪些
路徑分享:http://weahome.cn/article/iijhps.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部