我在通过xml文件导入初始数据时遇到了一点麻烦。例如,我将这个文件命名为myapp/fixtures/initial_data.xml:
<?xml version="1.0" encoding="UTF-8"?>
<rows>
<row>
<model>myapp.nutrition</model>
<name>Asiago Cheese Bagel</name>
<calories>370</calories>
<protein >17</protein >
<carbs>56</carbs>
<fats>8</fats>
<restaurant >Au Bon Pain</restaurant >
<price>1.29</price>
</row>
</rows>
我的模型文件是这样的:
from django.db import models
class Nutrition(models.Model):
name= models.CharField(max_length=100)
calories= models.IntegerField()
protein= models.IntegerField()
carbs= models.IntegerField()
fats= models.IntegerField()
restaurant= models.CharField(max_length=100)
price= models.DecimalField(decimal_places=2, max_digits=10)
当我运行manage.py loaddata myapp/fixtures/initial_data.xml时,我得到:从0个fixture安装0个对象(s)。我也尝试过JSON,得到了同样的结果。什么好主意吗?
你应该按照Django的要求来格式化XML。一种方法是使用Django的admin手动添加一个对象,然后使用
转储数据。manage.py dumpdata --format=xml --indent=4
对于您的情况,它给出类似
的内容<?xml version="1.0" encoding="utf-8"?>
<django-objects version="1.0">
<object pk="1" model="myapp.nutrition">
<field type="CharField" name="name">Asiago Cheese Bagel</field>
<field type="IntegerField" name="Calories">370</field>
...
</object>
</django-objects>