日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Pandas處理數(shù)據(jù)太慢,來試試Polars吧!

很多人在學(xué)習(xí)數(shù)據(jù)分析的時候,肯定都會用到Pandas這個庫,非常的實用!

“只有客戶發(fā)展了,才有我們的生存與發(fā)展!”這是創(chuàng)新互聯(lián)的服務(wù)宗旨!把網(wǎng)站當(dāng)作互聯(lián)網(wǎng)產(chǎn)品,產(chǎn)品思維更注重全局思維、需求分析和迭代思維,在網(wǎng)站建設(shè)中就是為了建設(shè)一個不僅審美在線,而且實用性極高的網(wǎng)站。創(chuàng)新互聯(lián)對成都網(wǎng)站制作、網(wǎng)站設(shè)計、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站制作、網(wǎng)站開發(fā)、網(wǎng)頁設(shè)計、網(wǎng)站優(yōu)化、網(wǎng)絡(luò)推廣、探索永無止境。

從創(chuàng)建數(shù)據(jù)到讀取各種格式的文件(text、csv、json),或者對數(shù)據(jù)進行切片和分割組合多個數(shù)據(jù)源,Pandas都能夠很好的滿足。

Pandas最初發(fā)布于2008年,使用Python、Cython和C編寫的。是一個超級強大、快速和易于使用的Python庫,用于數(shù)據(jù)分析和處理。

當(dāng)然Pandas也是有不足之處的,比如不具備多處理器,處理較大的數(shù)據(jù)集速度很慢。

今天給大家介紹一個新興的Python庫——Polars。

使用語法和Pandas差不多,處理數(shù)據(jù)的速度卻比Pandas快了不少。

一個是大熊貓,一個是北極熊~

GitHub地址:https://github.com/ritchie46/polars

使用文檔:https://ritchie46.github.io/polars-book/

Polars是通過Rust編寫的一個庫,Polars的內(nèi)存模型是基于Apache Arrow。

Polars存在兩種API,一種是Eager API,另一種則是Lazy API。

其中Eager API和Pandas的使用類似,語法差不太多,立即執(zhí)行就能產(chǎn)生結(jié)果。

而Lazy API就像Spark,首先將查詢轉(zhuǎn)換為邏輯計劃,然后對計劃進行重組優(yōu)化,以減少執(zhí)行時間和內(nèi)存使用。

安裝Polars,使用百度pip源。

# 安裝polars
pip install polars -i https://mirror.baidu.com/pypi/simple/

安裝成功后,開始測試,比較Pandas和Polars處理數(shù)據(jù)的情況。

使用某網(wǎng)站注冊用戶的用戶名數(shù)據(jù)進行分析,包含約2600萬個用戶名的CSV文件。

文件已上傳公眾號,獲取方式見文末。

import pandas as pd
df = pd.read_csv('users.csv')
print(df)

數(shù)據(jù)情況如下。

此外還使用了一個自己創(chuàng)建的CSV文件,用以數(shù)據(jù)整合測試。

import pandas as pd
df = pd.read_csv('fake_user.csv')
print(df)

得到結(jié)果如下。

首先比較一下兩個庫的排序算法耗時。

import timeit
import pandas as pd
start = timeit.default_timer()
df = pd.read_csv('users.csv')
df.sort_values('n', ascending=False)
stop = timeit.default_timer()
print('Time: ', stop - start)
-------------------------
Time: 27.555776743218303

可以看到使用Pandas對數(shù)據(jù)進行排序,花費了大約28s。

import timeit
import polars as pl
start = timeit.default_timer()
df = pl.read_csv('users.csv')
df.sort(by_column='n', reverse=True)
stop = timeit.default_timer()
print('Time: ', stop - start)
-----------------------
Time: 9.924110282212496

Polars只花費了約10s,這意味著Polars比Pandas快了2.7倍。

下面,我們來試試數(shù)據(jù)整合的效果,縱向連接。

import timeit
import pandas as pd
start = timeit.default_timer()
df_users = pd.read_csv('users.csv')
df_fake = pd.read_csv('fake_user.csv')
df_users.append(df_fake, ignore_index=True)
stop = timeit.default_timer()
print('Time: ', stop - start)
------------------------
Time: 15.556222308427095

使用Pandas耗時15s。

import timeit
import polars as pl
start = timeit.default_timer()
df_users = pl.read_csv('users.csv')
df_fake = pl.read_csv('fake_user.csv')
df_users.vstack(df_fake)
stop = timeit.default_timer()
print('Time: ', stop - start)
-----------------------
Time: 3.475433263927698

Polars居然最使用了約3.5s,這里Polars比Pandas快了4.5倍。

通過上面的比較,Polars在處理速度上表現(xiàn)得相當(dāng)不錯。

可以是大家在未來處理數(shù)據(jù)時,另一種選擇~

當(dāng)然,Pandas目前歷時12年,已經(jīng)形成了很成熟的生態(tài),支持很多其它的數(shù)據(jù)分析庫。

Polars則是一個較新的庫,不足的地方還有很多。

如果你的數(shù)據(jù)集對于Pandas來說太大,對于Spark來說太小,那么Polars便是你可以考慮的一個選擇。


當(dāng)前標(biāo)題:Pandas處理數(shù)據(jù)太慢,來試試Polars吧!
URL標(biāo)題:http://www.5511xx.com/article/cdosegd.html