2015-07-28 2 views
1

У меня есть .txt файл вроде этого:Создание .txt файла из словаря

ID - NAME - LASTNAME - USER - PASSWORD 

0001 - Oliver - Jackson - olson - pass123 

0002 - Samuel - Depp - samuel - pass321 

Затем я создал словарь из файла .txt:

{'0001': ['Oliver', 'Jackson', 'olson', 'pass123'], '0002': ['Samuel', 'Depp', 'samuel', 'pass321']} 

Теперь, если кто-то хочет для изменения одного из значений внутри словаря это легко, но мне нужно перезаписать файл .txt с такими новыми значениями, что-то вроде этого (пока не повезло):

{'0001': ['Oliver', 'Jackson', 'newlog01', 'newpass01'], '0002': ['Samuel', 'Depp', 'samuel', 'pass321']} 

0001 - Oliver - Jackson - newlog01 - newpass01 

. 

. 

. 

Thanks

+0

вы могли бы просто изменить строку в файл и запустить программу еще раз, чтобы создать словарь – letsc

+3

использовать родной Python модуль 'json'. Не нужно расточительствовать и конвертировать JSON. – Vidul

+0

Ваша структура данных обратная. Вместо создания 'dict', который указывает на' list', вы должны сделать 'list', который содержит' dict's: '[{'NAME': 'Oliver', 'LASTNAME': 'Jackson', 'USER ':' olson ',' PASSWORD ':' pass123 '}, {next user}, {etc.}] '. – TigerhawkT3

ответ

1

Это решение будет работать для вашей текущей системы, но рекомендуется не хранить эти данные в своем собственном формате. Вы должны просто использовать сборку в библиотеке json.

import json 

input = '{\"0001\": [\"Oliver\", \"Jackson\", \"newlog01\", \"newpass01\"], \"0002\": [\"Samuel\", \"Depp\", \"samuel\", \"pass321\"]}' 

data = dict() 

try: 
    data = json.loads(input) 
except ValueError as e: 
    print e 

print 'ID - NAME - LASTNAME - USER - PASSWORD' 
for key in sorted(data.keys()): 
    print ' - '.join([key] + data[key]) 

Выход:

ID - NAME - LASTNAME - USER - PASSWORD 
0001 - Oliver - Jackson - newlog01 - newpass01 
0002 - Samuel - Depp - samuel - pass321 
0

Вам придется заменить весь файл с новым содержанием

def read_file(filename): 
    data = {} 
    with open(filename, 'r') as fhd: 
     for line in fhd: 
      tokens = [token.strip() for token in line.split('-')] 
      data[tokens[0]] = tokens[1:] 
    return data 


def write_file(filename, data): 
    with open(filename, 'w') as fhd: 
     for key in sorted(data.keys()): 
      fhd.write('{} - {}\n'.format(key, ' - '.join(data[key]))) 

И использовать его как:

if __name__ == '__main__': 
    filename = 'test.dat' 
    data = read_file(filename) 
    data['0001'][1] = 'changed' 
    write_file(filename, data) 

Нет никакого способа обойти это. Данные на диске хранятся поочередно.

+0

Вам не нужно заменять весь файл. Вы можете использовать 'seek()' и 'write()', если будете осторожны. – Matt

+0

Вам нужно убедиться, что строка замены имеет тот же размер, что и заменяемая строка. И я вижу вашу точку зрения, вы можете взломать свой путь через решение, заставив каждое поле иметь зарезервированное количество байтов. – ikalvarado

0

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

например.

import os 

def encode(data): 
    header = "ID - NAME - LASTNAME - USER - PASSWORD" 
    lines = [' - '.join([key] + values) for (key, values) in data.iteritems()] 
    return (os.linesep+os.linesep).join([header] + lines) 

Тогда вы можете записать его обратно снова что-то вроде:

with open('data.txt','w') as f: 
    f.write(encode(d) + os.linesep) 
0

Во-первых, вы можете использовать json библиотеку, это очень хорошо для вашего проекта. , если вы не хотите использовать json файл, и вы должны изменить некоторые из ДАННЫЕ текстового файла:

import os 
new_txtfile=open("newfile.txt","w") 
def get_the_datas_from_your_txtfile(): 
    #on this function you can do change as you want with dictionary 
    # and now whrite the new dictionary to new_txtfile 
get_the_datas_from_your_txtfile() 
your_txtfile.close() 
new_txtfile.close() #her closing files 

os.remove("your_txtfile.txr") 
os.renames("new_txtfile.txt","your_txtfile.txt") 
#on thir we have removed the old file and changed the 
#new files name to old files name 
0

Это будет делать это примерно как можно плотнее.

d_map = {'0001': ['Oliver', 'Jackson', 'olson', 'pass123'], '0002': ['Samuel', 'Depp', 'samuel', 'pass321']} 
rv_str = '' 
for key in d_map.keys(): 
    rv_str += key + ' - ' + ' - '.join(d_map[key]) + '\n' 
with open('file.txt', 'w') as file_d: 
    file_d.write(rv_str) 
Смежные вопросы