我正在尝试从公共资源访问一些数据,但是尽管使用pip安装了模块fileio,但仍无法正常工作。这是我的代码:
from fileio import read
import gzip
odffn = 'test-data/Level1_IC59_data_Run00115150_Part00000000.odf.gz'
f = gzip.open(odffn)
ev = read(f)
hit_dist = list()
while ev :
# do some analysis with the event
hit_dist.append(len(ev.hits))
# get the next event
ev = read(f)
import pylab
pylab.hist(hit_dist,30,range=(0,1000), log=True, histtype='step')
pylab.title('IceCube Hit Distribution')
pylab.xlabel('nhit')
pylab.savefig('nhits.png')
然后出现以下错误:
from fileio import read
ModuleNotFoundError: No module named 'fileio'
但是,我已经使用pip安装程序进行了检查,
python -m pip install fileio
我得到模块已经安装。我认为PATH不会有问题,因为它可以与所有其他模型(即numpy)一起很好地工作,所以我不太确定可能是什么问题。预先感谢您的任何见识。
答案 0 :(得分:0)
我查看了fileio
的点子,据我所见,这似乎不是合法的软件包。从pip安装时,它不会安装任何可导入的Python模块或软件包。它所做的全部工作都会在site-packages
下创建一个骨架目录。
我认为您应该退后一步,重新评估这段代码在做什么:
from fileio import read
import gzip
odffn = 'test-data/Level1_IC59_data_Run00115150_Part00000000.odf.gz'
f = gzip.open(odffn)
ev = read(f)
hit_dist = list()
这看起来不错(忽略从fileio的导入),直到行ev = read(f)
。使用此功能读取gzip返回的文件对象的目的是什么?该对象具有自己的读取方法集,应该能够完成此工作:
import gzip
odffn = 'test-data/Level1_IC59_data_Run00115150_Part00000000.odf.gz'
f = gzip.open(odffn)
lines = f.readlines()
假设这是一个文本文件,应将整个内容读入字符串列表,每行一个。您还可以对其进行缓冲:
buf_size = 100
buf = f.read(buf_size)
while buf:
<do something with 1-100 characters of input>
buf = f.read(buf_size)
或缓冲整行:
line_buf = f.readline()
while line_buf:
<do something with a line of input>
line_buf = f.readline()