国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

python 使用pandas同時對多列進行賦值

瀏覽:4日期:2022-06-25 09:43:30
如dataframe

data1[’月份’]=int(month) #加入月份和企業名稱 data1[’企業’]=parmentname

可以增加單列,并賦值,如果想同時對多列進行賦值

data1[’月份’,’企業’]=int(month) , parmentname #加入月份和企業名稱

會出錯

ValueError: Length of values does not match length of index

data[[’合計’,’平均’]]=’數據’,’月份’

類似這樣的,也無效

KeyError: “None of [Index([‘合計’, ‘平均’], dtype=‘object’)] are in the [columns]”

只有下例中:

import pandas as pdchengji=[[100,95,100,99],[90,98,99,100],[88,95,98,88],[99,98,97,87],[96.5,90,96,85],[94,94,93,91],[91, 99, 92, 87], [85, 88, 85, 90], [90, 92, 99, 88], [90, 88, 89, 81], [85, 89, 89, 82], [95, 87, 86, 88], [90, 97, 97, 98], [80, 92, 89, 98], [80, 98, 85, 81], [98, 88, 95, 92]]data=pd.DataFrame(chengji,columns=[’語文’,’英語’,’數學’,’政治’])print (data)# data1=data[[’數學’,’語文’,’英語’,’政治’]] #排序# data1=data1.reset_index(drop=True) #序列重建# data1.index.names=[’序號’] #序列重命名# data1.index=data1.index+1 #序列從1開始# print (data1)data=pd.DataFrame(chengji,columns=[’語文’,’英語’,’數學’,’政治’],index=[i for i in range(1,len(chengji)+1)])print (data)data[[’合計’,’平均’]]=data.apply(lambda x: (x.sum(), x.sum()/4),axis=1,result_type=’expand’)print (data[:])data=pd.DataFrame(chengji,columns=[’語文’,’英語’,’數學’,’政治’],index=[i for i in range(1,len(chengji)+1)])print (data)data[[’合計’,’平均’]]=data.apply(lambda x:(’數據’,’月份’),axis=1,result_type=’expand’)print (data[:])

應用apply 并設置result_type=‘expand’ 參數才可以。

先前的例子,用如下的方法就行了

data1[[’月份’,’企業’]]=data1.apply(lambda x:(int(month),parmentname),axis=1,result_type=’expand’) # data1[’月份’]=int(month) #加入月份和企業名稱 # data1[’企業’]=parmentname #print (data1)后記:

如果’月份’,’企業’列存在,用如下也可,上例中,直接可以創建不存在的列。

data1.lco[:,[’月份’,’企業’]]=int(month),parmentname

data1[[’月份’,’企業’]]=int(month),parmentname

今天又遇到一個從某列截取字符串長度寫到另一列的,也一并寫到這里:

貨品列在原表中無,取貨品代碼的前12位。

totaldata = totaldata.reset_index(drop=False)totaldata[’貨品’] = totaldata[’貨品代碼’].apply(lambda x:x[:12])后記:2020.5.17又遇到想新增兩列并賦值的問題

import numpy as npimport pandas as pdfrom pandas import Series chengji = [[’N’, 95, 0], [’N’, 100, 88], [’N’, 88, 100], [’N’, 66, 0]]data = pd.DataFrame(chengji, columns=[’p’, ’x’, ’g’])data[[’序號’,’列名’]]=data[[’p’,’x’]] #pd.DataFrame(data[[’p’,’x’]])# .apply(lambda x : x )print(data)

補充:pandas 的apply返回多列,并賦值

代碼如下:

import pandas as pddf_tmp = pd.DataFrame([ {'a':'data1', 'cnt':100},{'a':'data2', 'cnt':200},])df_tmpa cntdata1 100data2 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_tmpa cnt fomat1 format2data1 100 data1100 100data1data2 200 data2200 200data2方法二:使用zip打包返回結果來處理

df_tmp['fomat1-1'], df_tmp['format2-2'] = zip(*df_tmp.apply(formatrow, axis=1))df_tmpa cnt fomat1 format2 fomat1-1 format2-2data1 100 data1100 100data1 data1100 100data1data2 200 data2200 200data2 data2200 200data2

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 国产特黄特色一级特色大片 | 日本男人天堂 | 怡红院在线观看 | 九久久 | 91欧美激情一区二区三区成人 | 亚洲自拍在线观看 | 加勒比一本大道香蕉在线视频 | 国产成人免费午夜性视频 | 频黄| 美女视频黄a全部 | avtt天堂网 手机资源 | 99九九成人免费视频精品 | 一级a性色生活片久久毛片 一级a做爰片欧欧美毛片4 | 美女张开腿黄网站免费 | 国内精品久久久久影院老司 | 国产精品一二区 | 国产精品久久久久久久久久久久 | 成年午夜性视频免费播放 | 亚洲高清成人欧美动作片 | 国产精品久久免费观看 | 国内精品影院久久久久 | 在线观看国产日韩 | 黄色三级视频 | 永久免费精品视频 | 亚欧成人毛片一区二区三区四区 | 亚洲狠狠ady亚洲精品大秀 | 成年人网站免费视频 | 福利社在线 | 国产男女视频在线观看 | 欧美日韩精品一区二区三区不卡 | 国产欧美视频一区二区三区 | 久久久国产精品网站 | 手机在线毛片 | a毛片久久免费观看 | 亚洲韩精品欧美一区二区三区 | 成人亚洲精品一区二区 | 欧美特级一级毛片 | 亚洲图片国产日韩欧美 | 欧美在线成人免费国产 | 香蕉网站狼人久久五月亭亭 | 欧美老妇免费做爰视频 |