텍스트 파일에 사전 쓰기?


96

사전이 있고 파일에 쓰려고합니다.

exDict = {1:1, 2:2, 3:3}
with open('file.txt', 'r') as file:
    file.write(exDict)

그런 다음 오류가 있습니다.

file.write(exDict)
TypeError: must be str, not dict

그래서 그 오류를 수정했지만 또 다른 오류가 발생했습니다.

exDict = {111:111, 222:222}
with open('file.txt', 'r') as file:
    file.write(str(exDict))

오류:

file.write(str(exDict))
io.UnsupportedOperation: not writable

나는 아직도 파이썬 초보자이기 때문에 무엇을 해야할지 모르겠다. 문제를 해결하는 방법을 아는 사람이 있으면 답변을 제공하십시오.

참고 : 저는 파이썬 2가 아닌 파이썬 3을 사용하고 있습니다.

답변:


154

우선 읽기 모드에서 파일을 열고 쓰기를 시도합니다. Consult- IO 모드 Python

둘째, 파일에 문자열 만 쓸 수 있습니다. 사전 객체를 작성하려면 문자열로 변환하거나 직렬화해야합니다.

import json

# as requested in comment
exDict = {'exDict': exDict}

with open('file.txt', 'w') as file:
     file.write(json.dumps(exDict)) # use `json.loads` to do the reverse

직렬화의 경우

import cPickle as pickle

with open('file.txt', 'w') as file:
     file.write(pickle.dumps(exDict)) # use `pickle.loads` to do the reverse

Python 3.x의 경우 pickle 패키지 가져 오기가 다를 수 있습니다.

import _pickle as pickle

1
작동했습니다! 그러나 사전의 내용 만 기록합니다. 다음과 같이 쓸 수 있습니까? exDict = {111 : 111, 222 : 222}
Nic

나는 그것을 생각했지만 더 나은 방법이 있다고 생각했습니다. 그래도 작동하므로 감사합니다!
Nic

당신이 =사인에 너무 집착하지 않는다면 내가 만든 편집이 그 일을 할 수있을 것이다.
hspandher

이전에 사용한 방식 : file.write ( 'exDict ='+ json.dumps (exDict)) 지금 사용하고 있으므로 잘 작동했습니다.
Nic

1
@JanKukacka JSON은 표준 데이터 형식입니다. 무엇을 str(exDict)생산할 것입니다 항상 유효한 JSON되지 않습니다. 내 머리 뒤에서 한 가지 이유는 작은 따옴표가 JSON 파일에서 유효하지 않지만 str메소드 를 사용할 때 존재할 수 있다는 것입니다.
hspandher

50

나는 파이썬 3에서 이렇게한다.

with open('myfile.txt', 'w') as f:
    print(mydictionary, file=f)

1
수입이 필요 없기 때문에 나는 이것을 좋아합니다. 위의 답변 data.write (str (dictionary))는 파일에 <class 'dict'>를 쓰기 때문에 올바른 사전에서 작동하지 않습니다
Si Mon

제가 또한 궁금한 점은 print (mydictionary, file = open ( 'myfile.txt', 'w'))
만하지 않는 이유입니다

@MadmanLee 나는 둘 다 괜찮다고 생각하며 우리 코드가 어떻게 보이는지 선호하는 문제입니다.
NKSHELL

1
open ( 'myfile.txt', 'r') as f : content = f.read (); dic = eval (내용);
NKSHELL

json이 str(mydict)파일에 쓰는 것보다 더 나은 이유 는 정확하게 객체를 되찾기 eval위해 내용이 필요하지 않기 때문 dict입니다. eval보안 목록이며 더 나은 옵션을 사용할 수있는 경우 사용해서는 안됩니다.
snakecharmerb

23
fout = "/your/outfile/here.txt"
fo = open(fout, "w")

for k, v in yourDictionary.items():
    fo.write(str(k) + ' >>> '+ str(v) + '\n\n')

fo.close()

12
코드 전용 답변은 문제 해결 방법을 설명하지 않으므로 권장하지 않습니다. 이 질문이 이미 수락하고 찬성 한 다른 답변에서 개선되는 점을 설명하기 위해 답변을 업데이트하십시오. 좋은 답변을 작성하는 방법을 검토하십시오 .
FluffyKitten

또한 with파일을 읽고 쓸 때 다음 명령문 을 사용해야 합니다. stackoverflow.com/questions/3012488/…
Falko

13

첫 번째 코드 블록을 사용하는 프로브는 'w'

with open('/Users/your/path/foo','w') as data:
    data.write(str(dictionary))

질문 내의 코드에 오류가 있으므로 이것은 정답입니다.
Ricardo Rivaldo 2018

json 경로를 시도 할 때 수레에 "NaN"값이 있기 때문에 실패합니다. JSON을 작성하려는 경우 데이터 자체를 손상시키지 않고는 수정할 수 없습니다. 따라서이 답변은 dict를 정확하게 반영하기 위해 텍스트 파일을 저장할 수 있기 때문에 선호되는 답변입니다.
pauljohn32

7

파일에서 이름으로 가져올 수 있고 잘 정렬되고 보존하려는 문자열이 포함 된 항목을 추가 할 수있는 사전을 원한다면 다음을 시도 할 수 있습니다.

data = {'A': 'a', 'B': 'b', }

with open('file.py','w') as file:
    file.write("dictionary_name = { \n")
    for k in sorted (data.keys()):
        file.write("'%s':'%s', \n" % (k, data[k]))
    file.write("}")

그런 다음 가져 오기 :

from file import dictionary_name

이것은 문자열에 대해서만 작동하고 사전의 다른 유형에는 작동하지 않습니다.
Paul Kenjora

4

목록 이해력 애호가를 위해 이것은 모든 key : value쌍을 새 줄로 작성합니다.dog.txt

my_dict = {'foo': [1,2], 'bar':[3,4]}

# create list of strings
list_of_strings = [ f'{key} : {my_dict[key]}' for key in my_dict ]

# write string one by one adding newline
with open('dog.txt', 'w') as my_file:
    [ my_file.write(f'{st}\n') for st in list_of_strings ]

1

나는 이것이 오래된 질문이라는 것을 알고 있지만 json을 포함하지 않는 솔루션을 공유하려고 생각했습니다. 데이터를 쉽게 추가 할 수 없기 때문에 개인적으로 json을 좋아하지 않습니다. 시작점이 사전 인 경우 먼저 데이터 프레임으로 변환 한 다음 txt 파일에 추가 할 수 있습니다.

import pandas as pd
one_line_dict = exDict = {1:1, 2:2, 3:3}
df = pd.DataFrame.from_dict([one_line_dict])
df.to_csv('file.txt', header=False, index=True, mode='a')

도움이 되었기를 바랍니다.


1
간단한 작업에 외부 라이브러리를 사용하는 이유는 무엇입니까? Python Simple이 더 나은 원칙입니다.
Ricardo Rivaldo 2018

내가 사용하는 대부분의 사전은 유용한 DataFrame 개체가 될만큼 간단하지 않기 때문에 그다지 유용하지 않습니다.
pauljohn32

1
exDict = {1:1, 2:2, 3:3}
with open('file.txt', 'w+') as file:
    file.write(str(exDict))


-2
import json

with open('tokenler.json', 'w') as file:
     file.write(json.dumps(mydict, ensure_ascii=False))

작동 이유에 대한 설명을 추가하여이 오류를 개선 할 수 있습니다.
Greg the Incredulous
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.