Список словаря - PullRequest
       16

Список словаря

1 голос
/ 06 мая 2009

В список возможно добавление. Но как мне добиться добавления в словарь?

    Symbols from __ctype_tab.o:
Name                  Value   Class        Type         Size     Line  Section
__ctype             |00000000|   D  |            OBJECT|00000004|     |.data
__ctype_tab         |00000000|   r  |            OBJECT|00000101|     |.rodata

Symbols from _ashldi3.o:
Name                  Value   Class        Type         Size     Line  Section
__ashldi3           |00000000|   T  |              FUNC|00000050|     |.text

Symbols from _ashrdi3.o:
Name                  Value   Class        Type         Size     Line  Section
__ashrdi3           |00000000|   T  |              FUNC|00000058|     |.text

Symbols from _fixdfdi.o:
Name                  Value   Class        Type         Size     Line  Section
__fixdfdi           |00000000|   T  |              FUNC|0000004c|     |.text
__fixunsdfdi        |        |   U  |            NOTYPE|        |     |*UND*

Как создать словарь:

dictOfTables {'__ctype_tab.o':{'__ctype': Name:...,Value:...,Class:...,Type:...,Size:...,Line:...,Section:...}} etc.

для вышеприведенного текста?

Ответы [ 2 ]

7 голосов
/ 06 мая 2009

Добавление не имеет смысла для словаря так же, как и для списка. Вместо этого более разумно говорить о вставке и удалении ключа / значений, так как нет « end » для добавления - дикт неупорядочен.

Исходя из вашего желаемого результата, похоже, что вы хотите, чтобы у вас был набор слов (например, {filename : { symbol : { key:value }}). Я думаю, что вы можете получить это из своего ввода с помощью чего-то вроде:

import re

header_re = re.compile('Symbols from (.*):')

def read_syms(f):
    """Read list of symbols from provided iterator and return dict of values"""
    d = {}
    headings=None
    for line in f:
        line = line.strip()
        if not line: return d  # Finished.

        if headings is None:
             headings = [x.strip() for x in line.split()]
             continue # First line is headings

        items = [x.strip() for x in line.split("|")]
        d[items[0]] = dict(zip(headings[1:], items[1:]))
    return d

f=open('input.txt')
d={}
for line in f:
    m=header_re.match(line)
    if m:
        d[m.group(1)] = read_syms(f)
1 голос
/ 06 мая 2009

Посмотрите, используя упорядоченный словарь . Я не думаю, что это пока что в официальном Python, но в PEP есть справочная реализация.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...