python中pandas操作apply返回多列的實現(xiàn)
我們可以用DataFrame的apply函數(shù)實現(xiàn)對多列,多行的操作。
需要記住的是,參數(shù)axis設為1是對列進行操作,參數(shù)axis設為0是對行操作。默認是對行操作。
apply 返回多列
# height = [70, 90, 100, 120, 140, 160, 180, 200,220,240, 260] # 長度為 11 # df.shape ? (1000, 11) # 對df的每一行的每一個元素操作,然后再返回多列 #----------返回多列----------------- df = df.apply(lambda x: pd.Series([math.atan(i[0]/(i[1])*180/math.pi for i in zip(height, x)]).astype(float), axis=1) .rename(columns=dict(zip(list(range(0, 11)), df.columns))) #df['slope'] = df_10min.apply(lambda x: math.atan(210 / (x['ws_260'] - x['ws_50'] + 1e-7))*180/math.pi, axis=1)
import pandas as pd df_tmp = pd.DataFrame([ ? ? {"a":"data1", "cnt":100},{"a":"data2", "cnt":200}, ]) df_tmp a?? ?cnt data1?? ?100 data2?? ?200 方法一:使用apply 的參數(shù)result_type 來處理 def formatrow(row): ? ? a = row["a"] + str(row["cnt"]) ? ? b = str(row["cnt"]) + row["a"] ? ? return a, b? ? df_tmp[["fomat1", "format2"]] = df_tmp.apply(formatrow, axis=1, result_type="expand") df_tmp a?? ?cnt?? ?fomat1?? ?format2 data1?? ?100?? ?data1100?? ?100data1 data2?? ?200?? ?data2200?? ?200data2 方法一:使用zip打包返回結果來處理 df_tmp["fomat1-1"], df_tmp["format2-2"] = zip(*df_tmp.apply(formatrow, axis=1)) df_tmp a?? ?cnt?? ?fomat1?? ?format2?? ?fomat1-1?? ?format2-2 data1?? ?100?? ?data1100?? ?100data1?? ?data1100?? ?100data1 data2?? ?200?? ?data2200?? ?200data2?? ?data2200?? ?200data2
生成新列
現(xiàn)在有如下一個DataFrame:
np.random.seed(1) df = pd.DataFrame(np.random.randn(4,2), columns=['A', 'B']) df >>> A B 0 1.624345 -0.611756 1 -0.528172 -1.072969 2 0.865408 -2.301539 3 1.744812 -0.761207
對A, B兩列操作,生成C列, 其中C是字符串,由A ± B組成。下面看一下結果就明白了。
df['C'] = df.apply(lambda x: '{:.2f}±{:.2f}'.format(x['A'], x['B']), axis=1)
看一下效果
A B C
0 1.624345 -0.611756 1.62±-0.61
1 -0.528172 -1.072969 -0.53±-1.07
2 0.865408 -2.301539 0.87±-2.30
3 1.744812 -0.761207 1.74±-0.76
多行操作舉例
同理可以作用在多行上。
# 對第 10 行進行操作,基于第2、3兩行 df.loc[10] = df.apply(lambda x: '{:.2f}±{:.2f}'.format(x[2], x[3]) )
看一下實現(xiàn)的效果
A B
0 1.624345 -0.611756
1 -0.528172 -1.072969
2 0.865408 -2.301539
3 1.744812 -0.761207
10 0.87±1.74 -2.30±-0.76
參考鏈接
[1] pandas的DataFrame使用apply實現(xiàn)對多列,多行操作 2021.12
[2] pandas 的apply返回多列,并賦值 2020.4
到此這篇關于python中pandas操作apply返回多列的實現(xiàn)的文章就介紹到這了,更多相關pandas apply返回多列內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- Python Pandas pandas.read_sql_query函數(shù)實例用法分析
- python?pandas創(chuàng)建多層索引MultiIndex的6種方式
- Python+pandas編寫命令行腳本操作excel的tips詳情
- Python Pandas實現(xiàn)DataFrame合并的圖文教程
- Python的Django框架實現(xiàn)數(shù)據庫查詢(不返回QuerySet的方法)
- Python中類似于jquery的pyquery庫用法分析
- python實現(xiàn)合并多個list及合并多個django QuerySet的方法示例
- python?pandas?query的使用方法
相關文章
python requests包的request()函數(shù)中的參數(shù)-params和data的區(qū)別介紹
這篇文章主要介紹了python requests包的request()函數(shù)中的參數(shù)-params和data的區(qū)別介紹,具有很好參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05關于vscode?默認添加python項目的源目錄路徑到執(zhí)行環(huán)境的問題
這篇文章主要介紹了vscode?默認添加python項目的源目錄路徑到執(zhí)行環(huán)境,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-02-02Python eval()與exec()函數(shù)使用介紹
exec函數(shù)執(zhí)行的是python語句,沒有返回值,eval函數(shù)執(zhí)行的是python表達式,有返回值,exec函數(shù)和eval函數(shù)都可以傳入命名空間作為參數(shù),本文給大家介紹下Python eval()和exec()函數(shù),感興趣的朋友跟隨小編一起看看吧2023-01-01Boston數(shù)據集預測放假及應用優(yōu)缺點評估
這篇文章主要為大家介紹了Boston數(shù)據集預測放假及應用優(yōu)缺點評估,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10