自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

讓你的Pandas代碼快得離譜的兩個(gè)技巧

開發(fā) 深度學(xué)習(xí)
在這篇文章中,筆者將分享兩個(gè)技巧,幫助你讓Pandas代碼快得離譜,提升數(shù)據(jù)處理效率并避免常見的陷阱。

如果你曾經(jīng)使用過Pandas處理表格數(shù)據(jù),你可能會熟悉導(dǎo)入數(shù)據(jù)、清洗和轉(zhuǎn)換的過程,然后將其用作模型的輸入。然而,當(dāng)你需要擴(kuò)展和將代碼投入生產(chǎn)時(shí),你的Pandas管道很可能開始崩潰并運(yùn)行緩慢。在這篇文章中,筆者將分享2個(gè)技巧,幫助你讓Pandas代碼快得離譜,提升數(shù)據(jù)處理效率并避免常見的陷阱。

技巧1:矢量化操作

在Pandas中,矢量化操作是一種強(qiáng)大的工具,它可以用一種更簡潔和高效的方式處理整個(gè)數(shù)據(jù)框的列,而不是逐行循環(huán)。

它是如何工作的?

廣播是矢量化操作的一個(gè)關(guān)鍵要素,它允許您直觀地操作具有不同形狀的對象。

eg1: 具有3個(gè)元素的數(shù)組a與標(biāo)量b相乘,得到與Source形狀相同的數(shù)組。

eg2: 在進(jìn)行加法運(yùn)算時(shí),將形狀為(4,1)的數(shù)組a與形狀為(3,)的數(shù)組b相加,結(jié)果會得到一個(gè)形狀為(4,3)的數(shù)組。

關(guān)于這一點(diǎn)已經(jīng)有很多文章,并且在深度學(xué)習(xí)中,大規(guī)模的矩陣乘法是非常常見的。在本文中,我們將利用兩個(gè)簡短的例子上進(jìn)行討論。

首先,假設(shè)您想要計(jì)算給定整數(shù)在列中出現(xiàn)的次數(shù)。以下是 2 種可能的方法。

"""
計(jì)算DataFrame X 中 "column_1" 列中等于目標(biāo)值 target 的元素個(gè)數(shù)。

參數(shù):
X: DataFrame,包含要計(jì)算的列 "column_1"。
target: int,目標(biāo)值。

返回值:
int,等于目標(biāo)值 target 的元素個(gè)數(shù)。
"""
# 使用循環(huán)計(jì)數(shù)
def count_loop(X, target: int) -> int:
    return sum(x == target for x in X["column_1"])

# 使用矢量化操作計(jì)數(shù)
def count_vectorized(X, target: int) -> int:
    return (X["column_1"] == target).sum()

現(xiàn)在假設(shè)有一個(gè)DataFrame帶有日期列并希望將其偏移給定的天數(shù)。使用矢量化操作計(jì)算如下:

def offset_loop(X, days: int) -> pd.DataFrame:
        d = pd.Timedelta(days=days)
    X["column_const"] = [x + d for x in X["column_10"]]
    return X

def offset_vectorized(X, days: int) -> pd.DataFrame:
    X["column_const"] = X["column_10"] + pd.Timedelta(days=days)
    return X

技巧2:迭代

「for循環(huán)」

第一個(gè)也是最直觀的迭代方法是使用Python for循環(huán)。

def loop(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) -> list[str]:
    res = []
    i_remove_col = df.columns.get_loc(remove_col)
    i_words_to_remove_col = df.columns.get_loc(words_to_remove_col)
    for i_row in range(df.shape[0]):
        res.append(
            remove_words(
                df.iat[i_row, i_remove_col], df.iat[i_row, i_words_to_remove_col]
            )
        )
    return result

「apply」

def apply(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) -> list[str]:
    return df.apply(
        func=lambda x: remove_words(x[remove_col], x[words_to_remove_col]), axis=1
    ).tolist()

在 df.apply 的每次迭代中,提供的可調(diào)用函數(shù)獲取一個(gè) Series,其索引為 df.columns,其值是行的。這意味著 pandas 必須在每個(gè)循環(huán)中生成該序列,這是昂貴的。為了降低成本,最好對您知道將使用的 df 子集調(diào)用 apply,如下所示:

def apply_only_used_cols(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) -> list[str]:
    return df[[remove_col, words_to_remove_col]].apply(
        func=lambda x: remove_words(x[remove_col], x[words_to_remove_col]), axis=1
    )

「列表組合+itertuples」

使用itertuples與列表相結(jié)合進(jìn)行迭代肯定會更好。itertuples生成帶有行數(shù)據(jù)的(命名)元組。

def itertuples_only_used_cols(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) -> list[str]:
    return [
        remove_words(x[0], x[1])
        for x in df[[remove_col, words_to_remove_col]].itertuples(
            index=False, name=None
        )
    ]

「列表組合+zip」

zip接受可迭代對象并生成元組,其中第i個(gè)元組按順序包含所有給定可迭代對象的第i個(gè)元素。

def zip_only_used_cols(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) -> list[str]:
    return [remove_words(x, y) for x, y in zip(df[remove_col], df[words_to_remove_col])]

「列表組合+to_dict」

def to_dict_only_used_columns(df: pd.DataFrame) -> list[str]:
        return [
            remove_words(row[remove_col], row[words_to_remove_col])
            for row in df[[remove_col, words_to_remove_col]].to_dict(orient="records")
        ]

「緩存」

除了我們討論的迭代技術(shù)之外,另外兩種方法可以幫助提高代碼的性能:緩存和并行化。如果使用相同的參數(shù)多次調(diào)用 pandas 函數(shù),緩存會特別有用。例如,如果remove_words應(yīng)用于具有許多重復(fù)值的數(shù)據(jù)集,您可以使用它functools.lru_cache來存儲函數(shù)的結(jié)果并避免每次都重新計(jì)算它們。要使用lru_cache,只需將@lru_cache裝飾器添加到 的聲明中remove_words,然后使用您首選的迭代方法將該函數(shù)應(yīng)用于您的數(shù)據(jù)集。這可以顯著提高代碼的速度和效率。以下面的代碼為例:

@lru_cache
def remove_words(...):
    ... # Same implementation as before

def zip_only_used_cols_cached(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) -> list[str]:
    return [remove_words(x, y) for x, y in zip(df[remove_col], df[words_to_remove_col])]

添加此裝飾器會生成一個(gè)函數(shù),該函數(shù)會“記住”之前遇到的輸入的輸出,從而無需再次運(yùn)行所有代碼。

「并行化」

最后一張王牌是使用 pandarallel 跨多個(gè)獨(dú)立的 df 塊并行化我們的函數(shù)調(diào)用。該工具易于使用:您只需導(dǎo)入并初始化它,然后將所有 .applys 更改為 .parallel_applys。

from pandarallel import pandarallel
pandarallel.initialize(nb_workers=min(os.cpu_count(), 12))

def parapply_only_used_cols(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) -> list[str]:
    return df[[remove_col, words_to_remove_col]].parallel_apply(
        lambda x: remove_words(x[remove_col], x[words_to_remove_col]), axis=1
    )
責(zé)任編輯:趙寧寧 來源: 郭小喵玩AI
相關(guān)推薦

2019-04-29 08:31:25

PythonPandas數(shù)據(jù)

2022-07-13 15:46:57

Python數(shù)據(jù)可視化代碼片段

2024-01-08 17:09:07

Python解釋器CPython

2019-11-25 10:20:54

CSS代碼javascript

2022-01-06 22:31:21

Python技巧代碼

2024-10-08 10:24:41

Python編程語言

2014-08-11 12:54:27

構(gòu)建模塊代碼審查編程

2020-08-06 00:25:38

Python代碼開發(fā)

2023-09-06 00:15:04

Pandas技巧格式

2024-01-03 14:54:56

PythonPandas數(shù)據(jù)處理工具

2024-04-29 06:50:45

Python代碼運(yùn)行

2011-09-20 15:19:15

Python

2010-11-22 15:48:40

MySQL修復(fù)表

2021-08-17 10:08:44

HTML網(wǎng)站網(wǎng)絡(luò)

2020-11-29 17:32:01

EmacsLinux

2022-09-19 15:02:24

C語言

2020-07-03 14:50:23

Python代碼編程語言

2024-02-26 16:40:58

2020-08-14 10:57:49

開發(fā)技能代碼

2013-12-18 10:34:42

OpenMP線程
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號