我有以下模型、视图和模板:
模型.py:
class Batch(models.Model):
material_id = models.ManyToManyField(AssetMetadata)
user = models.ForeignKey(User)
def __str__(self):
return 'Batch_' + str(self.pk) + '_' + self.user.username
class AssetMetadata(models.Model):
material_id = models.CharField(max_length=256, blank=True)
series_title = models.CharField(max_length=256, blank=True)
season_title = models.CharField(max_length=256, blank=True)
season_number = models.IntegerField(default=0)
episode_title = models.CharField(max_length=256, blank=True)
episode_number = models.IntegerField(default=0)
synopsis = models.TextField(max_length=1024, blank=True)
ratings = models.CharField(max_length=256, blank=True)
def __str__(self):
return self.material_id
Run Code Online (Sandbox Code Playgroud)
视图.py:
def assets_in_repo(request):
asset_list = AssetMetadata.objects.order_by('id').all()
page = request.GET.get('page', 1)
paginator = Paginator(asset_list, 50)
try:
assets = paginator.page(page)
except PageNotAnInteger:
assets = paginator.page(1)
except EmptyPage:
assets = paginator.page(paginator.num_pages)
if request.method == 'POST':
batch_list = request.POST.getlist('batch')
print(batch_list)
return render(request, 'assets_db/assets.html', {'assets': assets})
Run Code Online (Sandbox Code Playgroud)
模板片段:
<form method="post">{% csrf_token %}
<input type="submit" value="Create Batch" align="right">
<table class="table table-striped" id="myTable">
<tr>
<th>ID</th>
<th>Material ID</th>
<th>Series Title</th>
<th>Season Tile</th>
<th>Season Number</th>
<th>Episode Title</th>
<th>Episode Number</th>
<th>Create Batch</th>
</tr>
{% for i in assets %}<tr>
<td>{{i.pk}}</td>
<td><a href="/repo/{{ i.id}}">{{i.material_id}}</a></td>
<td>{{i.series_title}}</td>
<td>{{i.season_title}}</td>
<td>{{i.season_number}}</td>
<td>{{i.episode_title}}</td>
<td>{{i.episode_number}}</td>
<td>
<input type="checkbox" name="batch" value="{{i.pk}}">
</td>
</tr>{% endfor %}
</table>
</form>
Run Code Online (Sandbox Code Playgroud)
我正在尝试获取从复选框提供的数据并将其保存在模型中Batch。
用户选择资产来创建批次,表单返回pk这些资产的 ,AssetMetadata并且选择存储在通过 创建的列表中batch_list = request.POST.getlist('batch')。我想使用此列表中存储的数据创建一个新条目,然后在其中链接到中的Batch资产。pkAssetMetadata
我已经能够在 Django 管理页面中成功执行此操作,但理想情况下我会在视图中执行此操作。
我已阅读https://docs.djangoproject.com/en/1.10/ref/models/relations/并搜索 stackoverflow 但我对如何做到这一点感到困惑。
info = Batch.objects.create(season_title ='foo', .....)
info2= AssetMetadata.objects.create(material_id ='some')
info.material_id.add(info2)
Run Code Online (Sandbox Code Playgroud)
尝试这样的事情
| 归档时间: |
|
| 查看次数: |
8551 次 |
| 最近记录: |