我有python模块用于做一些事情,我需要在数据库中保存一些项目。
Currenlt我正在使用原始sql来插入数据。但我想使用django ORM。
我不需要任何网址,视图等我想要的只是我可以创建模型然后应该能够保存它像
user.save()
现在我不想在那里有不必要的文件和数据。但我不确定我需要哪些文件。我需要吗
settings.py
urls.py
views.py
app folder.
是否可以只有models.py
,然后在设置DATABASE config
。
我是否还需要创建一个应用程序
答案 0 :(得分:6)
你需要settings.py。您不需要urls.py或views.py。您将需要一个应用程序文件夹,并在settings.py中将该应用程序置于INSTALLED_APPS下。虽然有一种手动发现应用程序的方法,但它可能比您希望进入更多的工作。
您还需要运行迁移,并在此过程中创建迁移目录和文件。
在app目录中,你真正需要的只是__init__.py文件,迁移目录和models.py文件
在models.py中,有“来自django.db导入模型”,然后让你的模型继承自models.Model。
完成所有工作,你有一个非常准确的Django设置,用于使用你的模型与数据库交互
修改强>
为了解决这个问题,我开始了一个新的Django 1.9项目并开始屠杀settings.py文件,直到我破坏了一些东西。这就是我的开始:
"""
Django settings for Test project.
Generated by 'django-admin startproject' using Django 1.9.
For more information on this file, see
https://docs.djangoproject.com/en/1.9/topics/settings/
For the full list of settings and their values, see
https://docs.djangoproject.com/en/1.9/ref/settings/
"""
import os
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/1.9/howto/deployment/checklist/
# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = 'yp0at6d_bpr5a^j$6$#)(17tj8m5-^$p773lc6*jy%la!wu5!i'
# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True
ALLOWED_HOSTS = []
# Application definition
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'modeltest',
]
MIDDLEWARE_CLASSES = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
ROOT_URLCONF = 'Test.urls'
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
WSGI_APPLICATION = 'Test.wsgi.application'
# Database
# https://docs.djangoproject.com/en/1.9/ref/settings/#databases
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
# Password validation
# https://docs.djangoproject.com/en/1.9/ref/settings/#auth-password-validators
AUTH_PASSWORD_VALIDATORS = [
{
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
},
]
# Internationalization
# https://docs.djangoproject.com/en/1.9/topics/i18n/
LANGUAGE_CODE = 'en-us'
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = True
USE_TZ = True
# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.9/howto/static-files/
STATIC_URL = '/static/'
我还制作了一个示例github repo,以便您可以探索最小化设置的样子。 https://github.com/RobertTownley/BarebonesDjango
我能够在不破坏数据库交互的情况下完成的事情(只要我一次完成所有操作,并且在第一次运行迁移之前):
因此,在本实验结束时,我可以使用看起来像这样的settings.py文件与我的准系统模型(包括添加新字段)进行交互:
import os
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
SECRET_KEY = 'v7j%&)-4$(p&tn1izbm0&#owgxu@w#%!*xn&f^^)+o98jxprbe'
INSTALLED_APPS = ['modeltest']
ROOT_URLCONF = 'BarebonesTest.urls'
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
如果我知道sqlitedb所需位置的确切文件路径,或切换到postgres / mysql,我可以摆脱导入语句和BASE_DIR,将我的settings.py行总数减少到4个实质行( db setting,root_url,installed_apps和secret_key)
我喜欢被证明是错的(学习很有趣),但我认为你不能得到比这更小的settings.py文件:)
答案 1 :(得分:0)
对于Django 1.9,我只需要运行django-admin startproject
:settings.py后只有3个变量和manage.py的文件。这两个,加上来自wsgi.py
的一段代码,以及一些基本的目录结构元素,可以让您使用独立的ORM设置。实际上,如果您不想进行迁移,可以去掉manage.py。
以下是您的操作方式,以及GitHub为您自己播放的链接。
项目结构:
├── data
│ ├── __init__.py
│ ├── migrations
│ │ └── __init__.py
│ └── models.py
├── main.py
├── manage.py
└── settings.py
data
目录和迁移目录包含空__init__.py
个文件。示例models.py
文件如下所示:
from django.db import models
class User(models.Model):
name = models.CharField(max_length=255)
email = models.EmailField(max_length=255)
manage.py
文件是典型的Django manage.py
文件。如果您从新的os.environ.setdefault
命令复制它,请务必更改django-admin startproject
中的设置参数:
#!/usr/bin/env python
import os
import sys
if __name__ == "__main__":
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")
from django.core.management import execute_from_command_line
execute_from_command_line(sys.argv)
settings.py
文件需要3个设置:DATABASES,INSTALLED_APPS和SECRET_KEY。请参阅不是SQLite的DB的Django文档:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': 'sqlite.db',
}
}
INSTALLED_APPS = (
'data',
)
SECRET_KEY = 'REPLACE_ME'
真正的诀窍是main.py
,这是您可以针对模型进行编码的地方。显然你必须使用wsgi.py
中的一些代码来解决这两行问题:
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()
这是一个示例main.py:
# Django specific settings
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")
### Have to do this for it to work in 1.9.x!
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()
#############
# Your application specific imports
from data.models import *
#Add user
user = User(name="someone", email="someone@example.com")
user.save()
# Application logic
first_user = User.objects.all()[0]
print(first_user.name)
print(first_user.email)
This project以及this post是我找到答案的有用起点,我的Django 1.9工作代码的拉取请求已合并,因此您现在可以从masnun的repo中获取代码。如果您知道更好的方法,请提交拉取请求。