好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > pandas DataFrame 賦值的注意事項說明(index)

pandas DataFrame 賦值的注意事項說明(index)

熱門標簽:工廠智能電話機器人 原裝電話機器人 西藏智能外呼系統五星服務 在哪里辦理400電話號碼 400電話申請服務商選什么 平頂山外呼系統免費 清遠360地圖標注方法 千陽自動外呼系統 江蘇客服外呼系統廠家

一 pandas DataFrame一列賦值問題

說明,把b的列賦值給a

情況1:a,b index設置相同

如下代碼

import pandas as pd
import numpy as np
a = pd.DataFrame(np.arange(16).reshape(4,4),index=list('abcd'),columns=list('wxyz'))
b = pd.DataFrame(np.array([11,22,33,44]),index=list('abcd'),columns=['m'])
a['m'] = b['m']
print(a)

上述代碼結果如下

  w  x  y  z  m
a  0  1  2  3 11
b  4  5  6  7 22
c  8  9 10 11 33
d 12 13 14 15 44

情況一是最基本的情況,結果也符合預期,之所以符合預期是因為a,b都設有同樣的index,賦值操作按照index來到。如果b不設置Index,而是使用默認的index呢?

情況2:b的index采用默認值

代碼如下

import pandas as pd
import numpy as np
a = pd.DataFrame(np.arange(16).reshape(4,4),index=list('abcd'),columns=list('wxyz'))
b = pd.DataFrame(np.array([11,22,33,44]),columns=['m'])
a['m'] = b['m']
print(a)

結果如下

  w  x  y  z  m
a  0  1  2  3 NaN
b  4  5  6  7 NaN
c  8  9 10 11 NaN
d 12 13 14 15 NaN

情況二,結果超出了想象,b中的index為0,1,2,3與a中的index(‘a',‘b',‘c',‘d')不同,在賦值的過程中,是按照a中的index在b中找index相同位置的值,由于index不同,因此,給a賦值為NaN

情況三 : b中的部分Index與a中的相同

代碼如下

import pandas as pd
import numpy as np
a = pd.DataFrame(np.arange(16).reshape(4,4),index=list('abcd'),columns=list('wxyz'))
b = pd.DataFrame(np.array([11,22,33,44]),index=list('arpb'),columns=['m'])
a['m'] = b['m']
print(a)

結果如下

  w  x  y  z   m
a  0  1  2  3 11.0
b  4  5  6  7 44.0
c  8  9 10 11  NaN
d 12 13 14 15  NaN

由情況三結果可知,只有Index相同的行,賦值才能成功

總結:

從以上可以看出,Pandas DataFrame嚴格按照Index進行賦值,如果Index不同的話,則賦值為NaN

補充:python編程過程中DataFrame修改特定單元格值后原數據不變的一個解決方案

最近在參加了一個比賽,里面設計到數據清洗的工作,需要對一些異常值作出修改,往常我都是這樣操作的

df[condition]['column'].iloc[0:3] = ......

或者

df[condition]['column'][0:3] = ......

里面condition代表滿足條件的邏輯表達式,column表示列名

一般還是管用的,但偶爾會出現錯誤,主要是df[condition]這種表達在python里面是不夠規范的,因此運行以后單元格容易賦值失敗。在嘗試了很多種方法之后,最后還是使用規范的loc或者iloc表達

df.loc[[row condition],['column']] = ......

例如:

NA.loc[[23,29,49],'北美整體規模'] = ......

或者

df.iloc[np.where(condition),[1:3]]

注意loc里面接的是具體的行列名稱,iloc里面接的是滿足條件的行列名稱所對應的位置數字列表,切忌弄混!

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

您可能感興趣的文章:
  • 對pandas將dataframe中某列按照條件賦值的實例講解
  • pandas.DataFrame 根據條件新建列并賦值的方法
  • 淺談Pandas dataframe數據處理方法的速度比較
  • 使用pandas忽略行列索引,縱向拼接多個dataframe
  • Pandas.DataFrame轉置的實現
  • Pandas中DataFrame交換列順序的方法實現
  • 詳解pandas中利用DataFrame對象的.loc[]、.iloc[]方法抽取數據
  • Pandas中兩個dataframe的交集和差集的示例代碼

標簽:日照 安慶 西安 白城 隨州 股票 天水 錦州

巨人網絡通訊聲明:本文標題《pandas DataFrame 賦值的注意事項說明(index)》,本文關鍵詞  pandas,DataFrame,賦值,的,注意事項,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《pandas DataFrame 賦值的注意事項說明(index)》相關的同類信息!
  • 本頁收集關于pandas DataFrame 賦值的注意事項說明(index)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 用精水养大的公主小说| 日本老肥熟| 牝教师淫辱の教室无删| 欧洲美一区二区三区亚洲| 太粗太硬太深了太涨了轻点| 《隔壁人妻》无删减版| 老司机黄色软件| 亚洲另类激情综合偷自拍 | 182tv午夜福利香蕉| 国产美女黄网站免费视频| 我要看一级片| 女人扒开腿秘?免费网站| 国产欧美99热国产在线AV蜜臀 | 男女边摸边吃奶边做爽免费视频 | 99精品国产高清自在线看超| 小sao货水真多ji巴cao| 日本精品一区二区三区四区使用方法| 国语对白露脸无码AV精品| 同志小说又黄又刺激短篇小说| 亚洲第1页| 男子当街强吻并猛踹女孩 镇政府回应 | 边摸边脱边吃奶边做免费视频| 英语课代表的胸软软的感觉| 国产va无码精品一区二区三区| 美女被男人桶出白浆喷水| 欧美在线香蕉在线视频| 一伦一色一性一交一配| 谷原希美在线播放友人| 国产精品亚洲国产三区| 伊人222成人综合网| 啊插到子宫里了h| 日本高新1区2区3区| 厦门大学女厕照传网络在线观看| 色综合视频一区二区| 免费看黄色小说的网站| 美女的隐私视频观看软件| 51人人网理论电影天堂| 手鞠被爆漫画羞羞视频| 高H弱攻被各种强受睡来睡去| 爽爽影院在线18观看| 不健全关系漫画免费下拉式|