Чтение и редактирование файла шрифта и использование словаря - PullRequest
0 голосов
/ 15 декабря 2011

Мне нужно взять значения из текстового файла, который содержит координаты для рисования символов в TurtleWorld, пример текстового файла следующий:

<character=B, width=21, code=66>
4 21
4 0
-1 -1
4 21
13 21
16 20
17 19
18 17
18 15
17 13
16 12
13 11
-1 -1
4 11
13 11
16 10
17 9
18 7
18 4
17 2
16 1
13 0
4 0
</character>

Я должен тогда написатьфункция, позволяющая взять все эти точки и затем преобразовать их в словарь, где ключ - это символ, а соответствующие значения - это набор точек, которые можно использовать для рисования этого символа в TurtleWorld.

Код Iпробовал следующее:

def read_font():
    """
    Read the text from font.txt and convert the lines into instructions for how to plot specific characters
    """

    filename = raw_input("\n\nInsert a file path to read the text of that file (or press any letter to use the default font.txt): ")
    if len(filename) == 1:
        filename = 'E:\words.txt'
        words =  open(filename, 'r')
    else:
        words =  open(filename, 'r')

    while True:                                                                                 # Restarts the function if the file path is invalid
        line = words.readline()
        line = line.strip()
        if line[0] == '#' or line[0] == ' ':                                                    # Used to omit the any unwanted lines of text
            continue
        elif line[0] == '<' and line[1] == '/':                                                 # Conditional used for the end of each character
            font_dictionary[character] = numbers_list
        elif line[0] == '<' and line[1] != '/':                             

1 Ответ

0 голосов
/ 15 декабря 2011

взгляните на http://oreilly.com/catalog/pythonxml/chapter/ch01.html ::, в частности, выберите пример с названием :: Пример 1-1: bookhandler.py

, вы можете более или менее кредитовать / копировать это и настроить егочитать ваш конкретный XML.как только вы получите 'guts' (ваши координаты), вы можете легко разделить его на список координат x / y

, таких как

a = "1 3\n23 4\n3 9\n"
coords = map(int,a.split())

, и разбить его на список w/ groups of 2 Как разбить список на куски одинакового размера? и сохранить буквы результата [letter] = result

или вы можете сделать чанкинг более прикольным с помощью модуля re

import re
a = "1 13\n4 5\n"
b = re.findall("\d+ *\d+",a)
c = [map(int,item.split()) for item in b]
c
[[1, 13], [4, 5]]
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...