[英]parsing using multiple delimiters in python
我有一个数据文件,其中的数据用逗号,制表符和换行符分隔符存储,像这样
[32135, 311351, 88686
123152, 3153131, 131513
....]
我想从中提取一个nx3数组,我该怎么做?
尝试在分割线中使用分割,但它只是部分解析了文件
import numpy as np
filename="Elem_Output.inp"
f = open(filename,"r")
pmax=f.read()
p1=pmax.split()
我希望提取一行中每一行以及数组列中每一列中的数字的数组
在pmax = f.read()之后,您可能需要编写:
#Replace tab and newline as comma separater
pmax = pmax.replace("\n",",").replace("\t", ",")
#Replace repeated delimiter by a single instance
pmax = pmax.replace(",,,",",").replace(",,",",")
不用说,使用regex(import re)可以更好地编码它。
其次,如果您的文件以方括号开头和结尾,则可能需要另外添加:
pmax = pmax.replace("[","").replace("]","")
现在,如果要将此输出作为数组而不是列表,请尝试以下操作:
from array import array
array_pmax = array("B", pmax)
array()函数中的第一个参数指示类型代码。 要了解更多,只需使用help(array)
希望有帮助!!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.