python – 带有列表的子集pandas数据帧

我想根据几个变量列表对我的数据帧进行子集化,即:

list1=[var1,var2,var3]
 list2=[var4,var5,var6]

 data_final = data[list1,list2]

产生了这个错误

TypeError: unhashable type: 'list'

如果我提供一个列表,一切正常:

data_final = data[list1]

以下是最小例子:

dict1 = [{'var0': 0,'var1': 1,'var2': 2},{'var0': 0,'var1': 2,'var2': 4},{'var0': 1,'var1': 5,'var2': 8},'var1': 15,'var2': 12},]
 df = pd.DataFrame(dict1,index=['s1','s2','s3','s4'])

  list1=['var0']
  list2=['var1','var2']

这两个命令工作正常:

df[list1]
  df[list2]

但是这个产生了上面提到的错误

df[list1,list2]

解决方法

这是你期望的输出吗?

df[list1 + list2]
Out[106]: 
    var0  var1  var2
s1     0     1     2
s2     0     2     4
s3     1     5     8
s4     1    15    12

相关文章

功能概要:(目前已实现功能)公共展示部分:1.网站首页展示...
大体上把Python中的数据类型分为如下几类: Number(数字) ...
开发之前第一步,就是构造整个的项目结构。这就好比作一幅画...
源码编译方式安装Apache首先下载Apache源码压缩包,地址为ht...
前面说完了此项目的创建及数据模型设计的过程。如果未看过,...
python中常用的写爬虫的库有urllib2、requests,对于大多数比...