Форум сайта python.su
Задача весьма простая. Отношение 1 ко многим. Одной книге, сопоставляется несколько авторов. если я правильно понимаю, одной книге (id) должны сопоставляться id авторов. Но django генерит id автоматически, и непонятно, как получить этот идентификатор. В djangobook об этом ни слова. Простите за глупый вопрос. Начинаю делать первые шаги в области django с php такого не было.
Спасибо.
Офлайн
> Отношение 1 ко многим. Одной книге, сопоставляется несколько авторов.
ИХМО отношение будет многие ко многим.
> Но django генерит id автоматически, и непонятно, как получить этот идентификатор.
Зачем тебе его получать? Если нужно получить все книги автора, то фильтруешь объект книг по автору и всё.
Офлайн
благодарю за ответ.
!1) В таком случае нужна таблица, в которой указать это отношение или все произойдет само собой? Тогда как определять это отношение при добавлении в базу?
2) Не понял с юникодом, определять метод __unicode__ для всех текстовых полей или это нужно только для отображения в консоли. При отображении в шаблоне кодировка будет распознана верно.
Еще раз спасибо.
Офлайн
pal201Выбираешь книгу, для которой нужно определить автора:
Задача весьма простая. Отношение 1 ко многим. Одной книге, сопоставляется несколько авторов. если я правильно понимаю, одной книге (id) должны сопоставляться id авторов. Но django генерит id автоматически, и непонятно, как получить этот идентификатор. В djangobook об этом ни слова. Простите за глупый вопрос. Начинаю делать первые шаги в области django с php такого не было.
Спасибо.
authors = Book.objects.get(id=1)
authors = Book.authors.all()
authors = Book.objects.filter('Django')[0]
Отредактировано (Ноя. 20, 2011 16:12:11)
Офлайн
Благодарю Вас за ответ. Вы правы, id и не нужен вроде.
Продолжая углубляться в каменные джунгли Django не смог решит проблему отображения css даже после прочтения ссылок http://python.su/forum/viewtopic.php?id=5941 с уважаемого форума и djangobook.
Файл с css находится в /home/nik/Django-1.2.1/mysite/media/css.css
Шаблон /home/nik/Django-1.2.1/mysite/templates
в setting.py указано:
MEDIA_ROOT = ‘/home/nik/Django-1.2.1/mysite/media/’
MEDIA_URL = ‘/media/’
virws.py:
from django.shortcuts import render_to_response
def index(request):
return render_to_response('index.html',)
urls.py:
from django.conf.urls.defaults import patterns, include, url
from django.conf import settings
urlpatterns = patterns('',
('^$', ‘mysite.views.index’),
(r'^media/(?P<path>.*)$', ‘django.views.static.serve’, {'document_root':settings.MEDIA_ROOT}),
)
html:
…..
<meta http-equiv=“content-type” content=“application/xhtml+xml; charset=utf-8” />
<meta name=“author” content=“Haran” />
<link rel=“stylesheet” type=“text/css” href=“/media/css.css” title=“Purple Haze Stylesheet” />
…..
по адресу http://127.0.0.1:8000/media/css.css в ответе браузера:
Page not found: /media/css.css
однако в консоли сервера “GET / HTTP/1.1” 200 6158
Уже 2 дня не могу сделать отображение статики. Пожалуйста, помогите!
Отредактировано (Ноя. 20, 2011 20:39:19)
Офлайн
> В таком случае нужна таблица, в которой указать это отношение или все произойдет само собой? Тогда как определять это отношение при добавлении в базу?
Читай про тип поля models.ManyToManyField. Он сам создаст таблицу для связи.
Офлайн
pal201Попробуй так:
Уже 2 дня не могу сделать отображение статики. Пожалуйста, помогите!
(r'^media/(.*)$', 'django.views.static.serve', {
'document_root': settings.MEDIA_ROOT
})
Отредактировано (Ноя. 21, 2011 04:33:36)
Офлайн
Settings.py
# Django settings for mysite project.
DEBUG = True
TEMPLATE_DEBUG = DEBUG
ADMINS = (
# ('Your Name', ‘your_email@domain.com’),
)
MANAGERS = ADMINS
DATABASES = {
‘default’: {
‘ENGINE’: ‘mysql’, # Add ‘postgresql_psycopg2’, ‘postgresql’, ‘mysql’, ‘sqlite3’ or ‘oracle’.
‘NAME’: ‘mysite’, # Or path to database file if using sqlite3.
‘USER’: ‘pal2’, # Not used with sqlite3.
‘PASSWORD’: ‘123456’, # Not used with sqlite3.
‘HOST’: ‘localhost’, # Set to empty string for localhost. Not used with sqlite3.
‘PORT’: '', # Set to empty string for default. Not used with sqlite3.
}
}
# Local time zone for this installation. Choices can be found here:
# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
# although not all choices may be available on all operating systems.
# On Unix systems, a value of None will cause Django to use the same
# timezone as the operating system.
# If running in a Windows environment this must be set to the same as your
# system time zone.
TIME_ZONE = ‘America/Chicago’
# Language code for this installation. All choices can be found here:
# http://www.i18nguy.com/unicode/language-identifiers.html
LANGUAGE_CODE = ‘en-us’
SITE_ID = 1
# If you set this to False, Django will make some optimizations so as not
# to load the internationalization machinery.
USE_I18N = True
# If you set this to False, Django will not format dates, numbers and
# calendars according to the current locale
USE_L10N = True
# Absolute path to the directory that holds media.
# Example: “/home/media/media.lawrence.com/”
MEDIA_ROOT = ‘/home/nik/Django-1.2.1/mysite/media/’
# URL that handles the media served from MEDIA_ROOT. Make sure to use a
# trailing slash if there is a path component (optional in other cases).
# Examples: "http://media.lawrence.com“, ”http://example.com/media/“
MEDIA_URL = ‘/media/’
# URL prefix for admin media – CSS, JavaScript and images. Make sure to use a
# trailing slash.
# Examples: ”http://foo.com/media/“, ”/media/“.
ADMIN_MEDIA_PREFIX = ‘/media/’
# Make this unique, and don't share it with anybody.
SECRET_KEY = ‘+8ocqxwzv5!7l$5z7qkt&%bkwzoo@z4p=s%3&*0c%ghck0o9an’
# List of callables that know how to import templates from various sources.
TEMPLATE_LOADERS = (
‘django.template.loaders.filesystem.Loader’,
‘django.template.loaders.app_directories.Loader’,
# ‘django.template.loaders.eggs.Loader’,
)
MIDDLEWARE_CLASSES = (
# ‘django.middleware.common.CommonMiddleware’,
# ‘django.contrib.sessions.middleware.SessionMiddleware’,
# ‘django.middleware.csrf.CsrfViewMiddleware’,
# ‘django.contrib.auth.middleware.AuthenticationMiddleware’,
# ‘django.contrib.messages.middleware.MessageMiddleware’,
)
ROOT_URLCONF = ‘mysite.urls’
TEMPLATE_DIRS = (
# Put strings here, like ”/home/html/django_templates“ or ”C:/www/django/templates“.
# Always use forward slashes, even on Windows.
# Don't forget to use absolute paths, not relative paths.
”/home/nik/Django-1.2.1/mysite/templates",
)
INSTALLED_APPS = (
#'django.contrib.auth',
#'django.contrib.contenttypes',
#'django.contrib.sessions',
#'django.contrib.sites',
#'django.contrib.messages',
# Uncomment the next line to enable the admin:
# ‘django.contrib.admin’,
‘mysite’,
)
Офлайн
Settings.py
# Absolute path to the directory that holds media.
# Example: "/home/media/media.lawrence.com/"
MEDIA_ROOT = '/home/nik/Django-1.2.1/mysite/media/'
# URL that handles the media served from MEDIA_ROOT. Make sure to use a
# trailing slash if there is a path component (optional in other cases).
# Examples: "http://media.lawrence.com", "http://example.com/media/"
MEDIA_URL = '/media/'
# URL prefix for admin media -- CSS, JavaScript and images. Make sure to use a
# trailing slash.
# Examples: "http://foo.com/media/", "/media/".
ADMIN_MEDIA_PREFIX = '/media/admin/'
(r'^media/(.*)$', 'django.views.static.serve', {
'document_root': settings.MEDIA_ROOT
})
Офлайн
Вы просто маг и чародей!
заменил только это строку:
Kotakotaа вот (r'^media/(?P<path>.*)$', ‘django.views.static.serve’, {'document_root':settings.MEDIA_ROOT}), вернул на место и так же работает.
# URL prefix for admin media – CSS, JavaScript and images. Make sure to use a
# trailing slash.
# Examples: "http://foo.com/media/“, ”/media/".
ADMIN_MEDIA_PREFIX = ‘/media/admin/’
Офлайн