我想在 C++ 中重现以下 python 代码,但遇到了一些麻烦。函数 read_file 读取一个文本文件,测试每行中的第一个单词,看它是否是一个整数。如果第一个单词是整数(4 位或更多位),则该行上的所有单词都以浮点数形式添加到列表 z 中。在另一种情况下,该行只是作为字符串添加到列表中。列表 (z) 的列表被转换为 2D numpy 数组并返回其余部分。
def read_file(f):
srchp = re.compile(r'^\d{4,}\s') # beg. of line, digit min 4, white space
f = open(f)
rest = []
z = [x.strip() for x in f.readlines()] # read file, strip whitespace at beg./end of line,
#store in z as list of strings. each line is at its own offset
for i in range(len(z)-1,-1,-1):
if not srchp.search(z[i]): #if regex does not match
rest.append(z.pop(i)) #append to list rest
else:
z[i] = map(float,z[i].split())
f.close()
return numpy.array(z),rest
我应该为 C++ 中的容器使用哪些数据类型(向量的向量?数组?)?归根结底,我想用数组做一些统计分析。我将不胜感激将此代码转换为 C++ 的任何帮助。
以下是需要读取的文件的摘录。
TEMP_INF 700.000000 SCALAR
NAME VALUE TYPE DIMENSIONS
TEMP_REF 25.0000000 SCALAR
***** POST1 ELEMENT TABLE LISTING *****
STAT MIXED MIXED MIXED MIXED
ELEM X Y Z TEMP
23261 0.56292E-03 -0.96401E-02 0.24093 755.91
23262 -0.16635E-03 -0.97998E-02 0.24080 756.25
23263 -0.17039E-03 -0.10374E-01 0.24025 757.65
23264 0.12895E-02 -0.74483E-02 0.24242 751.64
23265 0.67515E-03 -0.80538E-02 0.24209 752.62
23266 0.10350E-02 -0.86614E-02 0.24164 753.92
23267 0.56032E-03 -0.88420E-02 0.24105 756.49
23268 0.13782E-02 -0.10792E-01 0.23978 758.74