- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个存储在 HDF5 文件中的大型 Pandas Dataframe。Dataframe 是具有 Datetime 和 PatientID 的多索引。
store = pd.HDFStore('prepro_mon.h5',mode='r')
print(store.get_storer('raw_import').levels)
Out: ['Datetime', 'PatientID']
但按患者 ID 过滤 Select 语句不起作用。
store.select('raw_import', where='PatientID = 88000')
我收到这个错误
Traceback (most recent call last):
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\io\pytables.py", line 4660, in generate
return Expr(where, queryables=q, encoding=self.table.encoding)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\pytables.py", line 524, in __init__
self.terms = self.parse()
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\expr.py", line 742, in parse
return self._visitor.visit(self.expr)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\expr.py", line 312, in visit
return visitor(node, **kwargs)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\expr.py", line 318, in visit_Module
return self.visit(expr, **kwargs)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\expr.py", line 312, in visit
return visitor(node, **kwargs)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\expr.py", line 321, in visit_Expr
return self.visit(node.value, **kwargs)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\expr.py", line 312, in visit
return visitor(node, **kwargs)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\expr.py", line 643, in visit_Compare
return self.visit(binop)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\expr.py", line 312, in visit
return visitor(node, **kwargs)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\expr.py", line 415, in visit_BinOp
op, op_class, left, right = self._possibly_transform_eq_ne(node)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\expr.py", line 353, in _possibly_transform_eq_ne
left = self.visit(node.left, side='left')
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\expr.py", line 312, in visit
return visitor(node, **kwargs)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\expr.py", line 429, in visit_Name
return self.term_type(node.id, self.env, **kwargs)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\pytables.py", line 41, in __init__
super(Term, self).__init__(name, env, side=side, encoding=encoding)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\ops.py", line 58, in __init__
self._value = self._resolve_name()
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\computation\pytables.py", line 47, in _resolve_name
raise NameError('name {0!r} is not defined'.format(self.name))
NameError: name 'PatientID' is not defined
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "H:\OxygenationIndex\dataloaderOIFeatures.py", line 51, in <module>
store.select('raw_import', where='PatientID = 88000')
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\io\pytables.py", line 724, in select
return it.get_result()
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\io\pytables.py", line 1423, in get_result
results = self.func(self.start, self.stop, where)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\io\pytables.py", line 717, in func
columns=columns, **kwargs)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\io\pytables.py", line 4266, in read
df = super(AppendableMultiFrameTable, self).read(**kwargs)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\io\pytables.py", line 4086, in read
if not self.read_axes(where=where, **kwargs):
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\io\pytables.py", line 3287, in read_axes
self.selection = Selection(self, where=where, **kwargs)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\io\pytables.py", line 4647, in __init__
self.terms = self.generate(where)
File "C:\Program Files\Anaconda3\lib\site-packages\pandas\io\pytables.py", line 4672, in generate
.format(where, ','.join(q.keys()))
ValueError: The passed where expression: PatientID = 88000
contains an invalid variable reference
all of the variable refrences must be a reference to
an axis (e.g. 'index' or 'columns'), or a data_column
The currently defined references are: SvO2,AWPMean,peep_s,SpO2,fiO2_m,TempCentral,tv_m,fiO2_s,HF,RR_s,TempPeri,etCO2,tv_s,peep_m,peakP_m,RR_m,columns,StayMinutes,VentMode,plateauP,index
非常感谢任何帮助。我不确定这是否是一个错误,因为我一直在阅读它应该可以按索引查询。
最佳答案
在使用 data_columns=True
参数保存 HDF 文件时,我可能会重现此错误。
演示:
index = pd.MultiIndex.from_product([pd.date_range('20170101',periods=4),
np.arange(1,5)],
names=['Datetime','PatientID'])
df = pd.DataFrame(dict(id2=np.random.randint(0, 1000, size=len(index)),
w=np.random.randn(len(index))),
index=index).reset_index().set_index(['Datetime','PatientID'])
df
产量:
In [54]: df
Out[54]:
id2 w
Datetime PatientID
2017-01-01 1 735 0.223941
2 262 1.057944
3 521 1.075384
4 500 0.932443
2017-01-02 1 372 -0.780629
2 489 -1.137088
3 836 1.862521
4 490 -1.150150
2017-01-03 1 366 -1.411923
2 763 -1.509591
3 779 -0.537362
4 672 0.312881
2017-01-04 1 549 1.670399
2 90 -2.265253
3 856 -0.780087
4 571 -0.498892
现在让我们将它保存到 HDF 文件中 - 一次不指定 data_columns
(默认值:None
),一次使用 data_columns=True
:
store = pd.HDFStore('d:/temp/41482523.h5', complib='blosc', complevel=9)
store.append('no_dc', df)
store.append('dc_true', df, data_columns=True)
两者具有相同的索引级别:
In [61]: store.get_storer('no_dc').levels
Out[61]: ['Datetime', 'PatientID']
In [62]: store.get_storer('dc_true').levels
Out[62]: ['Datetime', 'PatientID']
让我们尝试使用 where
子句进行选择:
In [63]: store.select('no_dc', where="PatientID==4")
Out[63]:
id2 w
Datetime PatientID
2017-01-01 4 500 0.932443
2017-01-02 4 490 -1.150150
2017-01-03 4 672 0.312881
2017-01-04 4 571 -0.498892
In [64]: store.select('dc_true', where="PatientID==4")
...
skipped
...
NameError: name 'PatientID' is not defined
...
skipped
...
ValueError: The passed where expression: PatientID==4
contains an invalid variable reference
all of the variable refrences must be a reference to
an axis (e.g. 'index' or 'columns'), or a data_column
The currently defined references are: columns,index,id2,w
解决方案:
如果你想索引列,你可以使用下面的技巧:
store.append('dc_all_cols', df, data_columns=df.iloc[[0]].reset_index().columns.tolist())
生成所有列的列表,包括 MultiIndex 列:
In [70]: df.iloc[[0]].reset_index().columns.tolist()
Out[70]: ['Datetime', 'PatientID', 'id2', 'w']
测试 select(where="...")
:
In [66]: store.select('dc_all_cols', where="PatientID==4")
Out[66]:
id2 w
Datetime PatientID
2017-01-01 4 500 0.932443
2017-01-02 4 490 -1.150150
2017-01-03 4 672 0.312881
2017-01-04 4 571 -0.498892
商店信息:
In [65]: store
Out[65]:
<class 'pandas.io.pytables.HDFStore'>
File path: d:/temp/41482523.h5
/dc_all_cols frame_table (typ->appendable_multi,nrows->16,ncols->4,indexers->[index],dc->[Datetime,PatientID,id2,w])
/dc_true frame_table (typ->appendable_multi,nrows->16,ncols->4,indexers->[index],dc->[id2,w])
/no_dc frame_table (typ->appendable_multi,nrows->16,ncols->4,indexers->[index],dc->[PatientID,Datetime])
HDF 存储中的索引列:
In [71]: store.get_storer('no_dc').table.colindexes
Out[71]:
{
"Datetime": Index(6, medium, shuffle, zlib(1)).is_csi=False,
"index": Index(6, medium, shuffle, zlib(1)).is_csi=False,
"PatientID": Index(6, medium, shuffle, zlib(1)).is_csi=False}
In [72]: store.get_storer('dc_true').table.colindexes
Out[72]:
{
"index": Index(6, medium, shuffle, zlib(1)).is_csi=False,
"id2": Index(6, medium, shuffle, zlib(1)).is_csi=False,
"w": Index(6, medium, shuffle, zlib(1)).is_csi=False}
In [73]: store.get_storer('dc_all_cols').table.colindexes
Out[73]:
{
"w": Index(6, medium, shuffle, zlib(1)).is_csi=False,
"index": Index(6, medium, shuffle, zlib(1)).is_csi=False,
"PatientID": Index(6, medium, shuffle, zlib(1)).is_csi=False,
"id2": Index(6, medium, shuffle, zlib(1)).is_csi=False,
"Datetime": Index(6, medium, shuffle, zlib(1)).is_csi=False}
关于python - 具有按索引值选择多索引的 Pandas HDFStore 找不到列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41482523/
我正在 csv 上使用 hadoop 来分析一些数据。我使用sql/mysql(不确定)来分析数据,现在陷入了僵局。 我花了好几个小时在谷歌上搜索,却没有找到任何相关的东西。我需要一个查询,在该查询中
我正在为 Bootstrap 网格布局的“简单”任务而苦苦挣扎。我希望在大视口(viewport)上有 4 列,然后在中型设备上有 2 列,最后在较小的设备上只有 1 列。 当我测试我的代码片段时,似
对于这个令人困惑的标题,我深表歉意,我想不出这个问题的正确措辞。相反,我只会给你背景信息和目标: 这是在一个表中,一个人可能有也可能没有多行数据,这些行可能包含相同的 activity_id 值,也可
具有 3 列的数据库表 - A int , B int , C int 我的问题是: 如何使用 Sequelize 结果找到 A > B + C const countTasks = await Ta
我在通过以下功能编写此查询时遇到问题: 首先按第 2 列 DESC 排序,然后从“不同的第 1 列”中选择 只有 Column1 是 DISTINCT 此查询没有帮助,因为它首先从第 1 列中进行选择
使用 Bootstrap 非常有趣和有帮助,目前我在创建以下需求时遇到问题。 “使用 bootstrap 在桌面上有 4 列,在平板电脑上有 2 列,在移动设备上有 1 列”谁能告诉我正确的结构 最佳
我是 R 新手,正在问一个非常基本的问题。当然,我在尝试从所提供的示例中获取指导的同时做了功课here和 here ,但无法在我的案例中实现这个想法,即可能是由于我的问题中的比较维度更大。 我的实
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个 df , delta1 delta2 0 -1 2 0 -1 0 0 0 我想知道如何分配 delt
您好,我想知道是否可以执行以下操作。显然,我已经尝试在 phpMyAdmin 中运行它,但出现错误。也许还有另一种方式来编写此查询。 SELECT * FROM eat_eat_restaurants
我有 2 个列表(标题和数据值)。我想要将数据值列 1 匹配并替换为头文件列 1,以获得与 dataValue 列 1 和标题值列 2 匹配的值 头文件 TotalLoad,M0001001 Hois
我有两个不同长度的文件,file2 是一个很大的引用文件,我从中提取文件 1 的数据。 我有一行 awk,我通常会对其进行调整以在我的文件中进行查找和替换,但它总是在同一列中进行查找和替换。 所以对于
假设我有两个表,如下所示。 create table contract( c_ID number(1) primary key, c_name varchar2(50) not
我有一个带有 varchar 列的 H2 表,其检查约束定义如下: CONSTRAINT my_constraint CHECK (varchar_field <> '') 以下插入语句失败,但当我删
这是最少量的代码,可以清楚地说明我的问题: One Two Three 前 2 个 div 应该是 2 个左列。第三个应该占据页面的其余部分。最后,我将添加选项来隐藏和
在 Azure 中的 Log Analytics 中,我为 VM Heartbeat 选择一个预定义查询,我在编辑器中运行查询正常,但当我去创建警报时,我不断收到警报“查询未返回 TimeGenera
在 Azure 中的 Log Analytics 中,我为 VM Heartbeat 选择一个预定义查询,我在编辑器中运行查询正常,但当我去创建警报时,我不断收到警报“查询未返回 TimeGenera
今天我开始使用 JexcelApi 并遇到了这个:当您尝试从特定位置获取元素时,不是像您通常期望的那样使用sheet.getCell(row,col),而是使用sheet.getCell(col,ro
我有一个包含 28 列的数据库。第一列是代码,第二列是名称,其余是值。 public void displayData() { con.Open(); MySqlDataAdapter
我很沮丧:每当我缩小这个网页时,一切都变得一团糟。我如何将网页居中,以便我可以缩小并且元素不会被错误定位。 (它应该是 2 列,但所有内容都合并为 1)我试过 但由于某种原因,这不起作用。 www.o
我是一名优秀的程序员,十分优秀!