Проблема configparser в python - PullRequest
       20

Проблема configparser в python

0 голосов
/ 15 сентября 2009

На самом деле я застрял в своей работе. Я хочу импортировать текстовый файл в мою программу на python, которая должна иметь два списка интергеров.

Следующая программа работает нормально, но мне нужно импортировать список 'a' и 'b' с помощью configparser.

Будет так здорово, если кто-нибудь поможет мне с этим!

Я новичок в Python, поэтому, пожалуйста, попробуйте ответить легким способом ...!

Программа выглядит следующим образом:

a=[5e6,6e6,7e6,8e6,8.5e6,9e6,9.5e6,10e6,11e6,12e6]

p=[0.0,0.001,0.002,0.003,0.004,0.005,0.006,0.007,0.008,0.009,0.01,0.015,0.05,0.1,0.15,0.2]

b=0

x=0

while b<=10:

    c=a[b]
    x=0

    print '\there is the outer loop\n',c


    while x<=15:

        k=p[x]

        print'here is the inner loop\n',k

        x=x+1

    b=b+1

Ответы [ 3 ]

0 голосов
/ 15 сентября 2009

Модуль json обеспечивает лучшую поддержку списков в файлах конфигурации. Вместо формата ConfigParser (без поддержки списка) попробуйте использовать для этой цели JSON.

JSON (JavaScript Object Notation) - это легкий формат обмена данными. Людям легко читать и писать. Машины легко разбираются и генерируются. Он основан на подмножестве языка программирования JavaScript, стандарт ECMA-262, 3-е издание - декабрь 1999 года. JSON - это текстовый формат, полностью независимый от языка, но использующий соглашения, знакомые программистам языков семейства C, включая C , C ++, C #, Java, JavaScript, Perl, Python и многие другие. Эти свойства делают JSON идеальным языком обмена данными.

Так как ваш вопрос пахнет домашней работой, я предлагаю уродливый хак Используйте str.split() и float() для анализа списка из файла конфигурации. Предположим, что файл x.conf содержит:

[sect1]
a=[5e6,6e6,7e6,8e6,8.5e6,9e6,9.5e6,10e6,11e6,12e6]

Вы можете разобрать его с помощью:

>>> import ConfigParser
>>> cf=ConfigParser.ConfigParser()
>>> cf.read(['x.conf'])
['x.conf']
>>> [float(s) for s in cf.get('sect1','a')[1:-1].split(',')]
[5000000.0, 6000000.0, 7000000.0, 8000000.0, 8500000.0, 9000000.0, 9500000.0, 10000000.0, 11000000.0, 12000000.0]
>>> 

(скобки вокруг списка могут быть удалены из файла конфигурации, что делает ненужным взломать [1:-1])

0 голосов
/ 15 сентября 2009

Да, парсер конфигурации, вероятно, не лучший выбор ... но если вы действительно хотите, попробуйте это:

import unittest
from ConfigParser import SafeConfigParser
from cStringIO import StringIO

def _parse_float_list(string_value):
    return [float(v.strip()) for v in string_value.split(',')]

def _generate_float_list(float_values):
    return ','.join(str(value) for value in float_values)

def get_float_list(parser, section, option):
    string_value = parser.get(section, option)
    return _parse_float_list(string_value)

def set_float_list(parser, section, option, float_values):
    string_value = _generate_float_list(float_values)
    parser.set(section, option, string_value)

class TestConfigParser(unittest.TestCase):
    def setUp(self):
        self.a = [5e6,6e6,7e6,8e6,8.5e6,9e6,9.5e6,10e6,11e6,12e6]
        self.p = [0.0,0.001,0.002,0.003,0.004,0.005,0.006,0.007,0.008,0.009,0.01,0.015,0.05,0.1,0.15,0.2]

    def testRead(self):
        parser = SafeConfigParser()
        f = StringIO('''[values]
a:   5e6,   6e6,   7e6,   8e6,
   8.5e6,   9e6, 9.5e6,  10e6,
    11e6,  12e6
p: 0.0  , 0.001, 0.002,
   0.003, 0.004, 0.005,
   0.006, 0.007, 0.008,
   0.009, 0.01 , 0.015,
   0.05 , 0.1  , 0.15 ,
   0.2
''')
        parser.readfp(f)
        self.assertEquals(self.a, get_float_list(parser, 'values', 'a'))
        self.assertEquals(self.p, get_float_list(parser, 'values', 'p'))

    def testRoundTrip(self):
        parser = SafeConfigParser()
        parser.add_section('values')
        set_float_list(parser, 'values', 'a', self.a)
        set_float_list(parser, 'values', 'p', self.p)

        self.assertEquals(self.a, get_float_list(parser, 'values', 'a'))
        self.assertEquals(self.p, get_float_list(parser, 'values', 'p'))

if __name__ == '__main__':
    unittest.main()
0 голосов
/ 15 сентября 2009

Похоже, ConfigParser не лучший инструмент для работы. Вы можете сами реализовать логику разбора примерно так:

a, b = [], []
with open('myfile', 'r') as f:
    for num, line in enumerate(f.readlines()):
        if num >= 10: 
            b.push(line)
        else:
            a.push(line)

или вы можете придумать другую логику для разделения списков в вашем файле. Это зависит от того, как вы хотите представить его в вашем файле

...