尝试从行开始读取文件并创建字典,跳过以#符号开头的行
文件示例:
param1=val1
# here is comment我的函数:
def readFromFile(name):
config = {}
with open(name, "r") as f:
for line in f.readlines():
li=line.lstrip()
if not li.startswith("#"):
config[line.split('=')[0]] = line.split('=')[1].strip()
return config我得到列表索引超出范围错误
但!如果我尝试跳过以符号"h“开头的行,例如,函数运行良好...
发布于 2013-07-31 20:02:06
尝试使用:
def readFromFile(name):
config = {}
with open(name, "r") as f:
for line in f.readlines():
li = line.lstrip()
if not li.startswith("#") and '=' in li:
key, value = line.split('=', 1)
config[key] = value.strip()
return config您可能有一个空行,这会打断您的拆分()
发布于 2013-07-31 20:01:52
除了既不以#开头也不包含=字符的行之外,您的代码运行得很好。通常,这些都是空行。
拆分前测试=字符:
def readFromFile(name):
config = {}
with open(name, "r") as f:
for line in f.readlines():
li=line.lstrip()
if not li.startswith("#") and '=' in li:
config[line.split('=')[0]] = line.split('=')[1].strip()
return config您可以简化代码并使其成为字典理解:
def readFromFile(name):
with open(name, "r") as f:
return {k: v
for line in f
for (k, v) in (line.strip().split('=', 1),)
if '=' in line.strip() and line[:1] != '#'}您可以直接循环遍历f (一个文件对象);不需要先使用f.readlines()将所有行读取到内存中。我使用.split('=', 1)只在等号上拆分了一次。
发布于 2013-07-31 20:06:45
您可以直接返回字典:
def readFromFile(name):
with open(name) as f:
return { line.split('=')[0]:line.split('=')[1].strip() for line in f \
if not line.startswith('#' and '=' in line } https://stackoverflow.com/questions/17969776
复制相似问题