我正在使用 Python 3,我需要从文件中提取数据。数据示例如下:ENERGY_BOUNDS 1.964033E+07 1.733253E+07 1.491825E+07 1.384031E+07 1.161834E+07 1.000000E+07 8.187308E+06 6.703200E+06 6.065307E+06 5.488116E+06 4.493290E+06 3.678794E+06 3.011942E+06 2.465970E+06 2.231302E+06 2.018965E+06GAMMA_INTERFACE 0EIGENVALUE 1.219034E+00N,2N 1.191994E+00 1.535081E+00 1.543891E+00 1.413861E+00 1.181815E+00 6.174152E-01 1.302440E-02 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00 0.000000E+00MACRO 1SIGABS -3.826074E-03 -3.707513E-04 2.610351E-03 6.961084E-03 7.832982E-03 7.512567E-03 1.018417E-02 1.276596E-02 9.148128E-03 8.828235E-03 8.527789E-03 7.514346E-03 7.544248E-03 7.801064E-03 7.724884E-03 7.047571E-03 5.280749E-03 3.999751E-03 3.821688E-03 3.748186E-03 3.712753E-03 3.591795E-03 3.390300E-03 3.180354E-03SIGTRAN 7.513455E-02 8.061355E-02 8.377954E-02 8.787775E-02 9.114071E-02 9.170817E-02 9.440786E-02 9.535947E-02 1.010975E-01 1.035364E-01 1.160553E-01 1.290131E-01 1.197249E-01 1.151962E-01 1.298934E-01 1.375417E-01 1.428861E-01 1.715100E-01 1.627465E-01 2.026621E-01 2.007540E-01 1.644982E-01 1.781501E-01 1.624188E-01该过程需要是:逐行搜索文件,直到找到起始关键字(在本例中为 MACRO)。之后继续逐行查找,直到找到特定的标识符。将标识符后面的行中的每个值读取到数组或列表中。一旦找到另一个标识符就停止读取。到目前为止,这就是我所拥有的。如果标识符是 MACRO 之后的第一个值(例如,如果它是 SIGABS),则代码可以正常工作,但对于任何其他值(例如,SIGTRAN)则不行。我的结果文件中可能有 50 个不同的标识符,因此我需要代码能够一次选出一个。
1 回答
jeck猫
TA贡献1909条经验 获得超7个赞
尝试以下操作。它将文件作为文本处理,分隔包含在 start_identifier 和 end_identifier 之间的部分,并通过一些工作返回最终在 list_of_results 中扩展的浮点列表(该列表必须在调用函数之前预先存在,因此您必须首先创建手动)。您可以运行任意一对标识符。让我知道它是如何运作的
def read_data_from_file_macro(file_name, start_identifier, end_identifier):
with open(file_name) as f:
t=f.read()
t=t[t.find('MACRO'):]
t=t[t.find(start_identifier)+len(start_identifier):t.find(end_identifier)]
t=t.replace('\n', '').split()
t=[float(i) for i in t if not i.isidentifier()]
list_of_results.extend(t)
添加回答
举报
0/150
提交
取消