pandas.DataFrame删除/选取含有特定数值的行或列
发布时间:2018-06-20 09:13,
浏览次数:9726
, 标签:
pandas
DataFrame
1.删除/选取某列含有特殊数值的行
import pandas as pd import numpy as np a=np.array([[1,2,3],[4,5,6],[7,8,9]])
df1=pd.DataFrame(a,index=['row0','row1','row2'],columns=list('ABC')) print(df1)
df2=df1.copy() #删除/选取某列含有特定数值的行 #df1=df1[df1['A'].isin([1])]
#df1[df1['A'].isin([1])] 选取df1中A列包含数字1的行 df1=df1[~df1['A'].isin([1])]
#通过~取反,选取不包含数字1的行 print(df1)运行结果:
2.删除/选取某行含有特殊数值的列
#删除/选取某行含有特定数值的列 cols=[x for i,x in enumerate(df2.columns) if df2.iat[0,i]==3]
#利用enumerate对row0进行遍历,将含有数字3的列放入cols中 print(cols) #df2=df2[cols] 选取含有特定数值的列
df2=df2.drop(cols,axis=1) #利用drop方法将含有特定数值的列删除 print(df2)
运行结果: