0

您好我在mac上使用python 3,我正在尝试创建一个通用程序来与一系列不同的万用表进行通信,具体取决于加载的文本文件。例如,我想要一个看起来像这样的字典:

prog_key  = {"DC_Volts":"FUNC:DC V","AC_Volts":"FUNC:AC V"...} #just an example

这最终将与 pyvisa 库结合使用,以便向仪表发送命令。

所以,为了使我的程序通用,我想要这本字典:

prog_key = {}

加载具有以下内容的文本文件:

"DC_Volt”:”FUNC:VOLT DC”,
"DC_Curr”:”FUNC:CURR DC”,
"AC_Volt”:”FUNC:VOLT AC”,
"AC_Curr”:”FUNC:CURR AC”,
"Res_2”:”FUNC:RES”,
"Res_4”:”FUNC:RES 4”,
"Freq”:”FUNC:FREQ”,
"Cap”:”FUNC:CAP”,
"Temp”:”FUNC:TEMP”,
"Diode”:”FUNC:DIO”,
“Meas”:”MEAS:IMM”

因为我将在文本文件中准备好它的格式,所以我实际上只是想将它转储到字典中(所有引号、冒号和逗号都将就位)。我这样做是因为不同的仪表会有不同的命令,所以如果我使用不同的仪表,我可以加载不同的文本文件。

我的命令有冒号这一事实会导致任何问题吗?

如果有更好的方法,我不介意重新格式化我的文本文件。主要的是,我使所有文本文件都遵循相同的趋势,只要它有效,trent 是什么并不重要!

谢谢

编辑:这些确实是直引号

4

3 回答 3

1

我认为格式化文件的更好方法(以避免处理逗号分隔符和冒号字段分隔符)是 CSV。例如,

"DC_Volt","FUNC:VOLT DC"
"DC_Curr","FUNC:CURR DC"
"AC_Volt","FUNC:VOLT AC"

这将允许您按如下方式读入您的字典:

import csv

my_dict = {}

with open('myfile.csv', 'r') as f:
  for line in csv.reader(f):
    my_dict[line[0]] = line[1]

编辑:就像@ShadowRanger 建议的那样,这对于 JSON 可能比 CSV 更好。(它可以让你保持你的键值格式)。

该文件可能如下所示:

{
  "DC_Volt":"FUNC:VOLT DC",
  "DC_Curr":"FUNC:CURR DC",
  "AC_Volt":"FUNC:VOLT AC"
}

你的代码可能是:

import json

with open('myfile.json', 'r') as f:
  j = json.load(f)
于 2016-03-21T19:24:14.543 回答
1

好吧,无需更改现有文件,因为您的键和值都是合法的str文字(假设那些智能引号是错误的),您可以让 Python 使用ast.literal_evalor完成工作json.loads

import ast
import json

with open(myfilename) as f:
    dict_literal_str = '{{ {} }}'.format(f.read())
# With ast
prog_key = ast.literal_eval(dict_literal_str)
# or json
prog_key = json.loads(dict_literal_str)
于 2016-03-21T19:24:20.780 回答
-1

这假定文件中的所有引号都是实际引号,"而不是其他类型的引号。它的作用是读取文件,匹配正则表达式并填充字典。

import re

dictionary = {}
file = open(FILE_NAME, "r")
for line in file:
   catched = re.findall("\"(.*)\":\"(.*)\"", line)
   # Only one result which is a tuple
   dictionary[catched[0][0]] = catched[0][1]
file.close()
于 2016-03-21T19:24:35.327 回答