django之基本配置
Python的WEB框架有Django、Tornado、Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM、模型绑定、模板引擎、缓存、Session等诸多功能。
零、安装
pip install django
一、创建django程序
- 终端命令:django-admin startproject sitename
- IDE创建Django程序时,本质上都是自动执行上述命令
其他常用命令:
python manage.py runserver 0.0.0.0 # 开始程序
python manage.py startapp appname # 程序内部增加新app
python manage.py syncdb
python manage.py makemigrations # 确认最新models的配置,如果与上一记录版本有出入,则生成新一版记录,与下面的migrate配对使用
python manage.py migrate # 根据信一半记录,修改数据库
python manage.py createsuperuser # 创建admin用户
启动程序
# dev
python manager.py startapp 0.0.0.0:8000 # master
gunicorn -w 4 xxadmin.wsgi # 4是cpu核数 # 下面是根据dev和master环境更改settings.py文件
wsgi.py
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'xxadmin.prod') manager.py
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'xxadmin.dev') # settings.py里的STATIC相关部分改成这样 STATIC_URL = '/static/'
if DEBUG:
STATICFILES_DIRS = (os.path.join(BASE_DIR, 'static'),)
else:
STATIC_ROOT = os.path.join(BASE_DIR, "static") # 对应的url改成这样
if not settings.DEBUG:
# 这里没必要,如果是prod环境,则需要在nginx做指向,这里临时这样写
urlpatterns += re_path(r'^static/(?P<path>.*)$', static.serve,
{'document_root': settings.STATIC_ROOT}, name='static'),
# dev环境由于STATICFILES_DIRS,不用上面这一步
二、程序目录

三、配置文件
1.数据库
############### settings.py ###############
# 使用sqllite,django默认
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
} # 使用mysql *******
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME':'dbname',
'USER': 'root',
'PASSWORD': 'xxx',
'HOST': '',
'PORT': '',
}
} ############### __init__.py ###############
# 由于Django内部连接MySQL时使用的是MySQLdb模块,而python3中还无此模块,所以需要使用pymysql来代替 # 如下设置放置的与project同名的配置的 __init__.py文件中 import pymysql
pymysql.install_as_MySQLdb()
2.模版
############### settings.py ###############
TEMPLATE_DIRS = (
os.path.join(BASE_DIR,'templates'),
)
3.静态文件(自定义放置插件的路径)
STATICFILES_DIRS = (
os.path.join(BASE_DIR,'static'),
)
4.新增app
################# settings ###############
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app01.apps.App01Config', # 注册app
]
四、直接执行某script
# -*- coding:utf-8 -*-
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "tmp_dj.settings") # NoQA
import django
django.setup() # NoQA if __name__ == '__main__':
''' 这里可以写django的逻辑,不需要侦听web端口了 '''
# -*- coding:utf-8 -*-
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "tmp_dj.settings") # NoQA
import django
django.setup() # NoQA if __name__ == '__main__':
from taiyingshi import models
import json
from django.db import transaction
from utils import logger
import re
import time error_log = logger.logger("error") dir = r"D:\临时\爬虫\scrapy\taiyingshi"
dir_walk = os.walk(dir) def get_duration(t):
if not t: return 0
h = re.findall("(\d+)小时", t)
h = 0 if not h else h[0]
M = re.findall("(\d+)分钟", t)
M = 0 if not M else M[0]
return int(h) * 60 + int(M) file_name_list = next(dir_walk)[2]
# print(len(file_name_list)) # 49666
movie_obj_list = models.Movie.objects.all()
movie_url_set = set(map(lambda obj:obj.url,movie_obj_list)) for idx,file_name in enumerate(file_name_list):
file_path = os.path.join(dir, file_name)
with open(file_path) as f:
movie_dict = json.load(f)
print(idx, movie_dict.get("movie_name"))
if movie_dict["movie_url"] not in movie_url_set:
try:
release_time = movie_dict.get("movie_year")
try:
release_time = time.strftime("%Y-%m-%d", time.strptime(release_time, "%Y"))
except:
release_time = None context = {
"name": movie_dict.get("movie_name"),
"url": movie_dict.get("movie_url"),
"release_time": release_time, # 直接格式化即可,这里顺便复习一下time模块
"length": get_duration(movie_dict.get("movie_length")),
"rate_douban": movie_dict.get("movie_rate_douban") or None,
"douban_link": movie_dict.get("movie_douban_link"),
"rate_imdb": movie_dict.get("movie_rate_imdb") or None,
"imdb_link": movie_dict.get("movie_imdb_link"),
"download_links": "\n".join(movie_dict.get("movie_download_list")),
} with transaction.atomic():
district = movie_dict.get("movie_district")
district_obj = models.District.objects.filter(district=district).first()
if not district_obj:
district_obj = models.District.objects.create(district=district) movie_obj = models.Movie.objects.create(district=district_obj, **context) # 从爬虫发过来的type set
movie_type_set = set(movie_dict.get("movie_type_list"))
# db里所有的type objs
movie_type_obj_list = models.Movie_type.objects.all()
# 转为set
movie_type_in_db_set = set(map(lambda obj: obj.movie_type, movie_type_obj_list))
# 需要新增的type
movie_type_to_db_set = movie_type_set - movie_type_in_db_set
# 增加新的type
if movie_type_to_db_set:
models.Movie_type.objects.bulk_create(
[models.Movie_type(movie_type=movie_type) for movie_type in movie_type_to_db_set])
# 增加m2m关系
if movie_type_set:
objs = models.Movie_type.objects.filter(movie_type__in=movie_type_set).all()
movie_obj.movie_types.add(*objs) # 没有手动增加的第三张表才能使用这样的添加方法 # 从爬虫发过来的language set
language_set = set(movie_dict.get("movie_language_list"))
# db里所有的language objs
language_obj_list = models.Languages.objects.all()
# 转为set
language_in_db_set = set(map(lambda obj: obj.language, language_obj_list))
# 需要新增的language
language_to_db_set = language_set - language_in_db_set
# 增加新的language
if language_to_db_set:
models.Languages.objects.bulk_create(
[models.Languages(language=language) for language in language_to_db_set]
)
# 增加m2m关系
if language_set:
language_objs = models.Languages.objects.filter(language__in=language_set).all()
models.Movie_m2m_Language.objects.bulk_create(
[models.Movie_m2m_Language(movie=movie_obj, language=language_obj) for language_obj in
language_objs]) # 从爬虫发过来的actor set
actor_set = set(movie_dict.get("movie_actor_list"))
# db里所有的actor objs
actor_obj_list = models.Actors.objects.all()
# 转为set
actor_in_db_set = set(map(lambda obj: obj.name, actor_obj_list))
# 需要新增的actor
actor_to_db_set = actor_set - actor_in_db_set
# 增加新的actor
if actor_to_db_set:
models.Actors.objects.bulk_create(
[models.Actors(name=actor) for actor in actor_to_db_set])
# 增加m2m关系
if actor_set:
actor_objs = models.Actors.objects.filter(name__in=actor_set).all()
models.Movie_m2m_Actor.objects.bulk_create(
[models.Movie_m2m_Actor(movie=movie_obj, actor=actor_obj) for actor_obj in actor_objs]
) # 从爬虫发过来的director set
director_set = set(movie_dict.get("movie_director_list"))
# db里所有的director objs
director_obj_list = models.Directors.objects.all()
# 转为set
director_in_db_set = set(map(lambda obj: obj.name, director_obj_list))
# 需要新增的director
director_to_db_set = director_set - director_in_db_set
# 增加新的director
if director_to_db_set:
models.Directors.objects.bulk_create(
[models.Directors(name=director) for director in director_to_db_set])
# 增加m2m关系
if director_set:
director_objs = models.Directors.objects.filter(name__in=director_set).all()
models.Movie_m2m_Director.objects.bulk_create(
[models.Movie_m2m_Director(movie=movie_obj, director=director_obj) for director_obj in
director_objs])
movie_url_set.add(movie_dict["movie_url"])
except Exception as e:
error_log.error("{} {}".format(movie_dict["movie_url"],str(e)))
实例,之前测试的script,把一些字典dump成的file传入db
依赖库
sudo apt-get install python3-dev libmysqlclient-dev
django之基本配置的更多相关文章
- Django的安装配置和开发
参考:<Django Web开发指南> Django的安装配置 1.https://www.djangoproject.com/download/下载Django-1.5.1.tar.gz ...
- django之uWSGI配置 +Nginx
参考文档 官方文档 安装: pip install uwsgi 启动命令: 方法一.直接命令启动 /home/zabbix/application/python/bin/uwsgi --socke ...
- django mysql 数据库配置
在settings.py中保存了数据库的连接配置信息,Django默认初始配置使用sqlite数据库. DATABASES = { 'default': { 'ENGINE': 'django.db. ...
- 55 Django静态文件配置
一.Django静态文件配置 1.项目文件夹,新建一个文件夹statics 文件夹 2.在配置文件settings.py中,配置: 文件中有第句: STATIC_URL = '/static/'#静态 ...
- Django 静态文件配置 (Nginx)
初学Django,在访问静态文件时候遇到很多误区,一直配置不成功,在此记录一下. Django静态文件访问分为两种:一种是Debug模式下,测试开发网站时对静态文件的访问,一种是实际生产环境中对静态文 ...
- python3-开发进阶Django-debug-toolbar的配置和Django logging的配置
阅读目录 django-debug-toolbar的配置 Django logging的配置 一.django-debug-toolbar的配置 1.介绍 django-debug-toolbar 是 ...
- django 自定义日志配置
如果不想使用 python 的 dictConfig 格式来配置 logger,可以制定自己的配置架构. LOGGING_CONFIG 配置定义了用来配置 django logger 的可调用函数,默 ...
- Web框架之Django_02基本操作(Django项目启动配置、数据库连接、orm、增删改查)
摘要: Django项目简单现实过程 pycharm连接数据库 Django之orm简单操作增删改查 一.新建Django项目.配置.设置: 新建Django项目:(为了熟悉Django操作,暂时全部 ...
- Django + Apache + wsgi配置和环境搭建(ubuntu)
上一篇写了Django + nginx + uwsgi配置和环境搭建(ubuntu) 由于公司服务器环境问题,又配置了apache的环境.记录例如以下: 一. 安装环境: #apache sudo a ...
- py文件单独调试django ORM的配置
1.新建一个py文件 2.代码环境搭建 import os if __name__ != '__main__': exit() # 加载django项目的配置信息 os.environ.setdefa ...
随机推荐
- python file的3中读法
f.read() 整个文件读入到内存,全部放入到一个string中 f.readlines() 文件全部内容解析成行列表,自带\n,需要print i, f.readline()一行一行,返回字符串 ...
- 2-51单片机ESP8266学习-AT指令(开发板51单片机自动冷启动下载原理)
前言:了解就行,不必深究 上一篇链接 http://www.cnblogs.com/yangfengwu/p/8720148.html 源码链接:https://pan.baidu.com/s/1wT ...
- 【html】文字排版
Web开发过程中文字排版,默认的情况下,行末的长单词会撑开容器. 我们想要的是(像word一样.能够自动换行.既不撑大容器.也不强制拆开行末单词.并且不会隐藏行末单词的多余字母) ①不能撑开容器 ②完 ...
- ThreadLocal理解
ThreadLocal 概述 ThreadLocal实例仅作为线程局部变量的==操作类==,以及==线程存储局部变量时的Key==.真正的线程局部变量是存储在各自线程的本地,通过Thread类中的Th ...
- centos配置静态ip地址
1.输入以下命令: vim /etc/sysconfig/network-scripts/ifcfg-eth0 2.注释掉BOOTPROTO=dhcp 3.添加如下内容: ONBOOT=yes 表示开 ...
- Redis数据类型基本操作
String类型: 设置键值对: set key value 设置键值对和过期时间:setex key seconds value ( 以秒为单位 ) 设置多个键值对: mset key1 value ...
- 【PHP开发规范】继承与扩展:PSR-2 编码风格规范
之前的一篇文章是对PSR-1的基本介绍 接下来是PSR-2 编码风格规范,它是 PSR-1 基本代码规范的继承与扩展. PSR-1 和PSR-2是PHP开发中基本的编码规范,大家其实都可以参考学习下, ...
- 【转】SQL中的锁、脏读、不可重复的读及虚读
原文:http://blog.csdn.net/wjeson/article/details/9382067 锁的概述 一. 为什么要引入锁 多个用户同时对数据库的并发操作时会带来以下数据不一致的问题 ...
- 20155327 java第四周学习笔记
20155327 java第四周学习笔记 五六章知识整理 1子类与父类 父类是接口或者是抽象类,子类必须继承自父类. 2子类的继承性 在Java中,通过关键字extends继承一个已有的类,被继承的类 ...
- 【BZOJ1002】[ZJOI2006]轮状病毒
[BZOJ1002]轮状病毒 题面 bzoj 题解 统计个数显然直接矩阵树定理,找规律截这里 打标如下: #include <iostream> #include <cstdlib& ...