J'ai un fichier comprenant deux colonnes, c'est-à-dire
1 a
2 b
3 c
Je souhaite lire ce fichier dans un dictionnaire tel que la colonne 1 représente la clé et la colonne 2 la valeur, c'est-à-dire
d = {1:'a', 2:'b', 3:'c'}
Le fichier est petit, donc l'efficacité n'est pas un problème.
d = {}
with open("file.txt") as f:
for line in f:
(key, val) = line.split()
d[int(key)] = val
Cela laissera la clé sous forme de chaîne:
with open('infile.txt') as f:
d = dict(x.rstrip().split(None, 1) for x in f)
Si votre version de Python est 2.7+, vous pouvez également utiliser un dict comprehension like:
with open('infile.txt') as f:
{int(k): v for line in f for (k, v) in (line.strip().split(None, 1),)}
def get_pair(line):
key, sep, value = line.strip().partition(" ")
return int(key), value
with open("file.txt") as fd:
d = dict(get_pair(line) for line in fd)
IMHO un peu plus Pythonic pour utiliser des générateurs (vous avez probablement besoin de 2.7+ pour cela):
with open('infile.txt') as fd:
pairs = (line.split(None) for line in fd)
res = {int(pair[0]):pair[1] for pair in pairs if len(pair) == 2 and pair[0].isdigit()}
Ceci filtrera également les lignes ne commençant pas par un entier ou ne contenant pas exactement deux éléments.
Voici une autre option ...
events = {}
for line in csv.reader(open(os.path.join(path, 'events.txt'), "rb")):
if line[0][0] == "#":
continue
events[line[0]] = line[1] if len(line) == 2 else line[1:]
import re
my_file = open('file.txt','r')
d = {}
for i in my_file:
g = re.search(r'(\d+)\s+(.*)', i) # glob line containing an int and a string
d[int(g.group(1))] = g.group(2)
Si vous aimez un paquebot, essayez:
d=eval('{'+re.sub('\'[\s]*?\'','\':\'',re.sub(r'([^'+input('SEP: ')+',]+)','\''+r'\1'+'\'',open(input('FILE: ')).read().rstrip('\n').replace('\n',',')))+'}')
Entrée FILE = Chemin du fichier, SEP = Caractère séparateur clé-valeur
Ce n’est pas le moyen le plus élégant et le plus efficace de le faire, mais néanmoins très intéressant :)