функция, обрабатывающая несколько строк и / или одну строку в файле - PullRequest
0 голосов
/ 21 ноября 2010

если у меня есть файл, как мне реализовать функцию, чтобы она могла читать как одну, так и несколько строк. например:

TimC
Tim Cxe
USA
http://www.TimTimTim.com
TimTim facebook!
ENDBIO
Charles
Dwight
END
Mcdon
Mcdonald 
Africa
      # website in here is empty, but we still need to consider it
      # bio in here is empty, but we need to include this in the dict
      # bio can be multiple lines
ENDBIO
Moon
King
END
etc

Мне просто интересно, может ли кто-нибудь использовать некоторые ключевые слова для начинающих на Python (например, не использовать yield, break, continue).

В моей собственной версии я определил 4 функции. 3 из 4 функций являются вспомогательными.

и я хочу, чтобы функция возвращала:

dict = {'TimC':{'name':Tim Cxd, 'location':'USA', 'Web':'http://www.TimTimTim.com', 'bio':'TimTim facebook!','follows': ['Charles','Dwight']}, 'Mcdon':{'name':Mcdonald , 'location':'Africa', 'Web':'', 'bio':'','follows': ['Moon','King']}}

Ответы [ 3 ]

1 голос
/ 21 ноября 2010
from itertools import izip

line_meanings = ("name", "location", "web")
result = {}
user = None

def readClean(iterable, sentinel=None):
    for line in iterable:
        line = line.strip()
        if line == sentinel:
            break
        yield line

while True:
    line = yourfile.readline()
    if not line:
        break
    line = line.strip()
    if not line:
        continue
    user = result[line] = {}
    user.update(izip(line_meanings, readClean(yourfile)))
    user['bio'] = list(readClean(yourfile, 'ENDBIO'))
    user['follows'] = set(readClean(yourfile, 'END'))

print result

{'Mcdon': {'bio': [''],
           'follows': set(['King', 'Moon']),
           'location': 'Africa',
           'name': 'Mcdonald',
           'web': ''},
 'TimC': {'bio': ['TimTim facebook!'],
          'follows': set(['Charles', 'Dwight']),
          'location': 'USA',
          'name': 'Tim Cxe',
          'web': 'http://www.TimTimTim.com'}}
0 голосов
/ 21 ноября 2010
import sys

def bio_gen(it, sentinel="END"):
    def read_line():
        return next(it).partition("#")[0].strip() 

    while True:
        key = read_line()
        ret = {
            'name': read_line(),
            'location': read_line(),
            'website': read_line(),
            'bio': read_line(),
            'follows': []}
        next(it)                    #skip the ENDBIO line
        while True:
            line = read_line()
            if line == sentinel:
                yield key, ret
                break
            ret['follows'].append(line)

all_bios = dict(bio_gen(sys.stdin))
import pprint
pprint.pprint(all_bios)

{'Mcdon': {'bio': '',
           'follows': ['Moon', 'King'],
           'location': 'Africa',
           'name': 'Mcdonald',
           'website': ''},
 'TimC': {'bio': 'TimTim facebook!',
          'follows': ['Charles', 'Dwight'],
          'location': 'USA',
          'name': 'Tim Cxe',
          'website': 'http://www.TimTimTim.com'}}
0 голосов
/ 21 ноября 2010

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

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