我有一个 HDF5 文件,h5dump
如下(省略无关内容)
HDF5 "file.h5" {
GROUP "/" {
DATASET "history" {
DATATYPE H5T_STRING {
STRSIZE H5T_VARIABLE;
STRPAD H5T_STR_NULLTERM;
CSET H5T_CSET_ASCII;
CTYPE H5T_C_S1;
}
DATASPACE SIMPLE { ( 1 ) / ( H5S_UNLIMITED ) }
DATA {
(0): "some string"
}
}
}
我正在尝试使用 h5py 从 python (3.5) 中读取。到目前为止我的尝试是
import h5py
F = h5py.File('file.h5', "r")
H = list()
for x in F['history']:
H.append(str(x))
但是
for x in H:
print(x)
产生
b'some string'
而不是简单地
some string
如何提取纯数据字符串?除了 str(x)
,我需要做什么?
附言这是我的第一个 python 问题,所以请多多包涵。
最佳答案
就用
H = [x.decode() for x in F['history']]
此列表理解将返回 H
作为字符串列表。
关于python - 如何使用 h5py 从 HDF5 数据集中读取字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35576999/