Skip to Content
Menu
This question has been flagged
1 Atsakyti
12013 Rodiniai

I needed to update the __openerp__.py file automatically, so I wrote the following code

import json as json 
with open('__openerp__.py','r+') as fl:     var = eval(fl.read())     var['data'].append('some_xml_file.xml')     fl.seek(0,0)     fl.truncate()     output = json.dumps(var, indent=4)     fl.write(output)

The problem with this code is that the json.dumps method outputs the key 

{...,
'installable': True,
...}


to 

{...,
"installable": true,
...}


So when the __openerp__.py file is being read again it will gives the error: 

NameError: name 'false' is not defined

I've written the following line to mend this problem

    ...
    output = output.replace(': false',': False').replace(': true',': True')
    fl.write(output)

My question is, How to update the __openerp__.py file correctly, i.e. as a python dictionary,  without appealing to this replace line of code


Portretas
Atmesti
Best Answer

Json dumps will bind the data and sends the result.

If it again needs to read, then you need to use Json Loads [json.loads() ] to unbind data created by dumps.


Portretas
Atmesti
Autorius

I know that I didn't use json.dumps the standard way, but I did this as I needed to update the __openerp__.py and save it formatted.

If I replaced the 7th line with

output = str(var)

it will save it as a dictionary in one line.

So if you can help me in this request your help will be appreciated

Related Posts Replies Rodiniai Veikla
0
saus. 21
12600
2
gruod. 19
8974
2
geg. 15
6738
0
kov. 15
5092
4
kov. 25
40614