私はDjango 1.5.4を使用しています
私はDjangoの初心者で、管理パネルからアップロードされた画像を表示しようとしましたが、残念ながら画像のソースコードのURLフィールドが空で、に変更{{ article.image.url }}
する{{ article.image }}
と画像のURLが次のように表示されます
<img src="media/abyss.jpg" alt="" height="450"/>
画像のリンクをクリックすると、
TypeError at /media/abyss.jpg
can only concatenate tuple (not "unicode") to tuple
私を助けてください。
Settings.py ファイル
MEDIA_ROOT = (os.path.join(os.path.dirname(__file__), '..', 'media').replace('\\','/'),)
MEDIA_URL = '/media/'
Models.py ファイル
class Article(models.Model):
title = models.CharField(max_length=255)
slug = models.SlugField(unique=True, max_length=255)
description = models.TextField()
content = models.TextField()
published = models.BooleanField(default=True)
image = models.ImageField(upload_to='media', blank=True)
created = models.DateTimeField(auto_now_add=True)
def __unicode__(self):
return u'%s' % self.title
class Meta:
ordering = ['-created']
def get_absolute_url(self):
return reverse('blog.views.article', args=[self.slug])
Urls.py
urlpatterns = patterns('',
url(r'^admin/', include(admin.site.urls)),
url(r'^$', 'blog.views.index'),
url(r'^blog/(?P<slug>[\w\-]+)/$', 'blog.views.article'),
url(r'^(.*)$', 'django.views.static.serve', {'document_root': settings.MEDIA_ROOT}),
)
index.html
{% extends "blog/base.html" %}
{% block content %}
<h1>PyStack</h1>
<div>
{% for article in articles %}
<img src="{{ article.image.url }}" alt="" height="450"/>
<h2><a href="{{ article.get_absolute_url }}">{{ article.title|capfirst }}</a></h2>
<p>{{ article.description }}</p>
<hr/>
{% endfor %}
</div>
{% endblock %}