python新手,搜尋不到自己想搜尋的內容。就例如從一個json設定檔讀取數據,然後根據這些數據,建立類別的對象,然後呼叫這些對象的方法。而這個json設定檔的資料是可以自由設定的。可能有一組數據,對應一個類別的物件。也可能有三組數據,對應三個類別的物件。
那該如何寫程式碼來讀取這個json資料再建立類別的物件?
比如說
Class targetobject(object):
def __init__(attr1,attr2):
def func1(self):
...
而我們的json資料是... ..."object1":{"attr1":"dawdad","attr2":"dwagfreg"},"object2":{"attr1":"45324523", "attr2":"45634"},
至於實際資料也不見得叫object1 object2,可能是其他名稱。而我要讀取這個json檔案之後,建立類別的對象,並賦予json中的資料
扔个三星炸死你2017-06-12 09:24:44
樓主是要動態建立物件吧。可以用exec 建立
a = {"object1": {"attr1": "dawdad", "attr2": "dwagfreg"}, "object2": {"attr1": "45324523", "attr2": "45634"}}
for obj_name in a:
exec ('class %s(object):pass' % (obj_name))
for attr in a[obj_name]:
exec ('%s.%s="%s"' % (obj_name, attr, a[obj_name][attr]))
print(object1.attr1)
輸出 dawdad
你也可以用type 創建
class targetobject(object):
def __init__(self, attr1, attr2):
self.attr1 = attr1
def func1(self):
pass
if __name__ == '__main__':
a = {"object1": {"attr1": "dawdad", "attr2": "dwagfreg"}, "object2": {"attr1": "45324523", "attr2": "45634"}}
for obj_name in a:
obj = type(str(obj_name), (targetobject,), a[obj_name])
print(obj)
print(obj.attr1)
滿天的星座2017-06-12 09:24:44
Python 創建類別的時候不一定要給齊成員(也就是說所有Python物件都是不固定的)
eg.
class A:
pass
a.b = 1 # 可以通过
a.__dict__['c'] = 2 # 使用__dict__获取数据成员
print(a.b) # 1
print(a.c) # 2
所以只要讀取Json,再給隨便什麼物件加入Json裡對應的資料成員就好了
为情所困2017-06-12 09:24:44
聽樓主好像要的是這種結構:
# coding: utf-8
from collections import namedtuple
obj = {"object1":{"attr1":"dawdad","attr2":"dwagfreg"}, "object2":{"attr1":"45324523","attr2":"45634"}}
obj_insts = []
for obj_name in obj:
obj_attr = obj[obj_name]
attrs = obj_attr.keys()
attr_values = obj_attr.values()
Obj = namedtuple(obj_name, attrs)
obj_insts.append(Obj(*attr_values))
print(obj_insts)
print(ibj_insts[0].attr1)
[object1(attr2='dwagfreg', attr1='dawdad'), object2(attr2='45634', attr1='45324523')]
dawdad
如果是設定文件,建議用toml(https://github.com/toml-lang/...
安裝python toml,就可以使用。
伊谢尔伦2017-06-12 09:24:44
其實我覺得你應該是想將文件中的json
資料,變成可以操作的物件, 就類似字典
那樣..看下json
庫是否滿足要求吧:
cat 1.txt:
{"object1":{"attr1":"dawdad","attr2":"dwagfreg"},"object2":"attr1":"45324523","attr2":"45634"}}
# python交互shell
>>> import json
>>> a = json.load(open('1.txt'))
>>> a
{u'object1': {u'attr2': u'dwagfreg', u'attr1': u'dawdad'}, u'object2': {u'attr2': u'45634', u'attr1': u'45324523'}}
>>> a['object1']
{u'attr2': u'dwagfreg', u'attr1': u'dawdad'}