使用Python 2.7和ConfObj / Parser进行麻烦的DAT编辑

时间:2017-04-25 18:42:24

标签: python ini configparser configobj

编辑 - 如果有兴趣,请点击这里的最终开源代码。 https://github.com/qetennyson/ConfigFileBuilder

您好,第一个问题在这里。我对Python比较陌生(在这里使用2.7)并且一直是一个非常普通的程序员。

我正在制作一个简短的程序,为这些专有的,互联网连接的电源开关构建配置文件,我有大约90个。每个都需要一个独特的配置,它将要去的城市。

我不知道大量的文件类型,但是这些家伙都是DAT,我认为它与INI类似,让我能够在键盘上敲打六到七个小时,几年,时间。

这是我现有的代码。

from configobj import ConfigObj
import csv
import os

config = ConfigObj('configtest3.dat', list_values=True, raise_errors=False)

with open('config.csv') as csvfile:
    csvreader = csv.reader(csvfile, dialect='excel')
    office = 'null'
    while (office != 'LASTOFFICEINLIST'):
        for row in csvreader:
            config.filename = row[0] + '-powerswitch'
            config['Hostname'] = row[0]
            config['Ipaddr'] = row[2]
            config['OutletName1'] = row[3]
            config['Gateway'] = row[4]
            config['DNS'] = 'DNSTEST'
            config['Account1'] = row[6]
            config['Password1'] = 'passwordtest'
            config['TimeServer1'] = 'x.x.x.x' <--Sanitized
            config['TimeZone'] = '800'
            office = row[0]
            config.write()

您正在考虑“应该可以正常工作”而且确实如此,只有一个例外!

如果我不从DAT文件的开头删除“默认”(如此处所示):

#The following line must not be removed.
Default
SSID1=MegaBoot_112D36
WebInit=1

...然后ConfObj将拒绝阅读它(我假设这是一个键/值问题)。

我没有在配置中没有“默认”的情况下测试其中一个设备,但是我倾向于听这条线路告诉我不要删除它,而且我不想砖块设备真。

在我的初学者中,我做了一些更多的研究,并意识到我能做的就是以编程方式删除默认值,然后在我完成ConfObj工作后将其添加回来,但我想先在这里查看。另外,我能够轻松地获得“默认”:

with open ('configtest3.dat', 'r+') as f:
    config = f.readlines()
    f.seek(0)
    for i in config:
        if i != 'Default\n':
            f.write(i)
        f.truncate()

......但我不确定如何将它拔回来。

我可能会把这整个事情搞得一团糟!

请赐教。

<小时/>

问题解决了!感谢您的反馈毛衣男爵。

这是我的最终代码,这可能与某些重构有关,但我会做到这一点。我终于有了一个功能齐全的配置生成器!

from configobj import ConfigObj
import csv
import os

config = ConfigObj('configtest.dat', list_values=True, raise_errors=False)

with open('config.csv') as csvfile:
    configcsv = csv.reader(csvfile, dialect='excel')
    office = 'null'
    while (office != 'Wooster'):
        for row in configcsv:
            config.filename = row[0] + '-powerswitch.dat'
            config['Hostname'] = row[0]
            config['Ipaddr'] = row[2]
            config['OutletName1'] = row[3]
            config['Gateway'] = row[4]
            config['DNS'] = 'DNSTEST'
            config['Account1'] = row[6]
            config['Password1'] = 'passwordtest'
            config['TimeServer1'] = '10.116.65.17'
            config['TimeZone'] = '800'
            office = row[0]
            config.write()

with open('config.csv') as csvfile:
    configcsv = csv.reader(csvfile, dialect='excel')
    csvfile.seek(0)
    office = 'null'
    while (office != 'Wooster'):
        for row in configcsv:
            filename = row[0] + '-powerswitch.dat'
            with open(filename, 'r') as cfgFile:
                almostCorrect = cfgFile.read()
            correct = "#The following line must not be removed.\nDefault\n" + almostCorrect
            with open(filename, 'w') as cfgFile:
                cfgFile.write(correct)
            print row[0]
            office = row[0]

我意识到我被挂起的一件事就是最初删除“默认”。相反,我只是从我正在配置90个文件的基本文件中删除了它。我不知道为什么我认为我首先需要它,如果我只是想把它添加到最后!

再次感谢。

1 个答案:

答案 0 :(得分:0)

这是一种智力上懒惰的解决方案,但似乎只需要对现有代码进行微小的更改:

使用现有代码创建没有“默认”行的配置文件。然后将该文件作为字符串读回Python。然后从文件中删除所有内容,向其中添加“Default”行,然后写回刚刚从中读取的文件的所有其他内容。

以下代码将“Default”添加到文本文件的开头(也不是很好的代码,只是说明我的意思):

with open("ConfigFilePath", "r") as cfgFile:
    almostCorrect = cfgFile.read()
correct = "Default\n" + almostCorrect
# Overwrite the original file with our new string which has "Default" at the beginning:
with open("ConfigFilePath", "w") as cfgFile:
    cfgFile.write(correct)