網站首頁 編程語言 正文
我們可以用DataFrame的apply函數實現對多列,多行的操作。
需要記住的是,參數axis設為1是對列進行操作,參數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 的參數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
生成新列
現在有如下一個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]) )
看一下實現的效果
? ? ? ?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實現對多列,多行操作 2021.12
[2] pandas 的apply返回多列,并賦值 2020.4
原文鏈接:https://blog.csdn.net/weixin_46713695/article/details/125958501
相關推薦
- 2022-10-05 Iptables防火墻string模塊擴展匹配規則_安全相關
- 2022-01-30 判斷element Ui 表格(el-table)中復選框中的選中狀態
- 2024-04-07 mybatis-plus插入數據庫值無效(插入不對,沒有插入數據庫默認值,int的類型的null會變
- 2022-06-12 C語言數學問題與簡單DP01背包問題詳解_C 語言
- 2022-10-22 Oracle根據時間查詢的一些常見情況匯總_oracle
- 2022-10-19 C#實現自動生成電子印章_C#教程
- 2022-12-10 Qt中簡單的按鈕槽函數傳遞參數方法_C 語言
- 2022-09-09 Nginx使用自簽ssl證書實現https連接的方法_nginx
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支