создавать приспособления с помощью пользовательских методов менеджера, дампов json и способов избежать ошибки типа: xxx не является сериализуемым json - PullRequest
0 голосов
/ 07 апреля 2011

Я пытаюсь создать тестовое устройство с помощью пользовательских методов менеджера, так как мое приложение использует подмножество таблиц dbtable и меньше записей. поэтому я отбросил идею использования initial_data. В менеджере я делаю что-то вроде этого. в Managers.py:

sitedict = Site.objects.filter(pk=1234).values()[0]
custdict = Customer.objects.filter(custid=123456).values()[0]
customer = {"pk":123456,"model":"myapp.customer","fields":custdict}
site = {"pk":0001,"model":"myapp.site","fields":sitedict}
csvfile = open('shoppingcart/bsofttestdata.csv','wb')
csv_writer = csv.writer(csvfile) 
csv_writer.writerow([customer,site])

Затем я изменил свой CSV-файл, чтобы заменить одинарные кавычки на двойные и т. Д. Затем я сохранил этот файл как json.Извините, если это слишком глупо, но я впервые создаю testdata, я бы с удовольствием Чтобы узнать лучше. Пример данных файла выглядит так: myapp / fixtures / testdata.json

[{"pk": 123456, "model": "myapp.customer", "fields": {"city": "abc", "maritalstatus": None, "zipcode": "12345", "lname": "fdfdf", "state": "AZ", "agentid": 1111, "fname": "sdadsad", "email": "abcd@xxx.com", "phone": "0000000000", "custid":123456,"datecreate": datetime.datetime(2011, 3, 29, 11, 40, 18, 157612)}},{"pk":0001, "model": "myapp.site", "fields": {"url": "http://google.com", "websitecode": "", "notify": True, "fee": 210.0, "id":0001}}]

Я использовал это для запуска своих тестов, но я получил следующую ошибку:

EProblem installing fixture '/var/lib/django/myproject/myapp/fixtures/testdata.json':    
    Traceback (most recent call last):
      File "/usr/lib/pymodules/python2.6/django/core/management/commands/loaddata.py", line 150, in handle
        for obj in objects:
      File "/usr/lib/pymodules/python2.6/django/core/serializers/json.py", line 41, in Deserializer
        for obj in PythonDeserializer(simplejson.load(stream)):
      File "/usr/lib/pymodules/python2.6/simplejson/__init__.py", line 267, in load
        parse_constant=parse_constant, **kw)
      File "/usr/lib/pymodules/python2.6/simplejson/__init__.py", line 307, in loads
        return _default_decoder.decode(s)
      File "/usr/lib/pymodules/python2.6/simplejson/decoder.py", line 335, in decode
        obj, end = self.raw_decode(s, idx=_w(s, 0).end())
      File "/usr/lib/pymodules/python2.6/simplejson/decoder.py", line 353, in raw_decode
        raise ValueError("No JSON object could be decoded")
    ValueError: No JSON object could be decoded

1 Ответ

1 голос
/ 07 апреля 2011

вместо использования raw find replace лучше использовать что-то , как показано здесь , и когда у нас есть некоторые типы данных, которые не поддерживает JSON. было бы полезно избавитьсяTypeError: xxxxxxx не поддерживает сериализацию в формате JSON или, в частности, сообщение о стеке для проблемы времени и времени будет полезно.

РЕДАКТИРОВАТЬ: вместо записи в CSV, а затем вручную изменить его, я сделал следующее:

with open('myapp/fixtures/customer_testdata.json',mode = 'w') as f:
    json.dump(customer,f,indent=2)

вот небольшой код, который я использовал для выхода из TypeError: xxxx не json бла-бла проблема

for key in cust.keys():
    value = cust[key]
    if isinstance(cust[key],datetime.datetime):
        temp = cust[key].timetuple() # this converts datetime.datetime to time.struct_time
        cust.update({key:{'__class__':'time.asctime','__value__':time.asctime(temp)}})
return cust

если мы конвертируем datetime.datetime в любой другой тип, то мы должны соответствующим образом изменить класс.Например, отметка времени -> float здесь фантастическая ссылка для преобразований даты и времени

Надеюсь, это полезно.

...