Writing a dictionary to a text file?
Andrew Mclaughlin
I have a dictionary and am trying to write it to a file.
exDict = {1:1, 2:2, 3:3}
with open('file.txt', 'r') as file: file.write(exDict)I then have the error
file.write(exDict)
TypeError: must be str, not dictSo I fixed that error but another error came
exDict = {111:111, 222:222}
with open('file.txt', 'r') as file: file.write(str(exDict))The error:
file.write(str(exDict))
io.UnsupportedOperation: not writableI have no idea what to do as I am still a beginner at python. If anyone knows how to resolve the issue, please provide an answer.
NOTE: I am using python 3, not python 2
10 Answers
First of all you are opening file in read mode and trying to write into it. Consult - IO modes python
Secondly, you can only write a string to a file. If you want to write a dictionary object, you either need to convert it into string or serialize it.
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 reverseIn case of serialization
import cPickle as pickle
with open('file.txt', 'w') as file: file.write(pickle.dumps(exDict)) # use `pickle.loads` to do the reverseFor python 3.x pickle package import would be different
import _pickle as pickle 12 I do it like this in python 3:
with open('myfile.txt', 'w') as f: print(mydictionary, file=f) 7 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() 2 The probelm with your first code block was that you were opening the file as 'r' even though you wanted to write to it using 'w'
with open('/Users/your/path/foo','w') as data: data.write(str(dictionary)) 2 If you want a dictionary you can import from a file by name, and also that adds entries that are nicely sorted, and contains strings you want to preserve, you can try this:
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("}")Then to import:
from file import dictionary_name 1 For list comprehension lovers, this will write all the key : value pairs in new lines in 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 ] I know this is an old question but I also thought to share a solution that doesn't involve json. I don't personally quite like json because it doesn't allow to easily append data. If your starting point is a dictionary, you could first convert it to a dataframe and then append it to your txt file:
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')I hope this could help.
2exDict = {1:1, 2:2, 3:3}
with open('file.txt', 'w+') as file: file.write(str(exDict)) You can do as follow :
import json
exDict = {1:1, 2:2, 3:3}
file.write(json.dumps(exDict)) import json
with open('tokenler.json', 'w') as file: file.write(json.dumps(mydict, ensure_ascii=False)) 1