前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Django2.0中文(进阶用法)

Django2.0中文(进阶用法)

作者头像
用户5760343
发布2022-05-14 14:03:14
2240
发布2022-05-14 14:03:14
举报
文章被收录于专栏:sktjsktj

1、URL传参与view

urls.py

views.py

from django.shortcuts import render_to_response from mysite.models import MyModel

def foobar_view(request, template_name): m_list = MyModel.objects.filter(is_new=True) return render_to_response(template_name, {'m_list': m_list}) 2、 URL /mydata/dec/31/ -- urlpatterns = patterns('', (r'^mydata/(?P<month>\w{3})/(?P<day>\d\d)/$', views.my_view), ) -- def my_view(request, month, day): # .... 3、通用视图

urls.py

views.py

from django.shortcuts import render_to_response

def object_list(request, model): obj_list = model.objects.all() template_name = 'mysite/%s_list.html' % model.name.lower() return render_to_response(template_name, {'object_list': obj_list}) 4、缺省视图参数

urls.py

views.py

def page(request, num='1'): # Output the appropriate page of blog entries, according to num. # ... 5、url传参都是字符串类型 def day_archive(request, year, month, day): date = datetime.date(int(year), int(month), int(day)) 6、url传参选择post get

views.py

from django.http import Http404, HttpResponseRedirect from django.shortcuts import render_to_response

def method_splitter(request, GET=None, POST=None): if request.method == 'GET' and GET is not None: return GET(request) elif request.method == 'POST' and POST is not None: return POST(request) raise Http404

def some_page_get(request): assert request.method == 'GET' do_something_for_get() return render_to_response('page.html')

def some_page_post(request): assert request.method == 'POST' do_something_for_post() return HttpResponseRedirect('/someurl/')

urls.py

from django.conf.urls.defaults import * from mysite import views

urlpatterns = patterns('', # ... (r'^somepage/$', views.method_splitter, {'GET': views.some_page_get, 'POST': views.some_page_post}), # ... ) 7、自动转义:autoescape {% autoescape off %} Hello {{ name }} {% endautoescape %} 8 default默认值需要自己转义 {{ data|default:"3 < 2" }} <-- Bad! Don't do this. 9、自定义标签/自定义过滤器 10 foreignkey

b = Book.objects.get(id=50) b.publisher <Publisher: Apress Publishing> b.publisher.website u'http://www.apress.com/' p.book_set.all() p = Publisher.objects.get(name='Apress Publishing') p.book_set.filter(name__icontains='django') [<Book: The Django Book>, <Book: Pro Django>]

image.png 11 manytomanyfield class Book(models.Model): title = models.CharField(max_length=100) authors = models.ManyToManyField(Author) publisher = models.ForeignKey(Publisher) publication_date = models.DateField() num_pages = models.IntegerField(blank=True, null=True)

代码语言:javascript
复制
def __unicode__(self):
    return self.title

12 django.db.models.Manager.title_count()

image.png

13 修改返回的集合:get_query_set() from django.db import models

# First, define the Manager subclass. class DahlBookManager(models.Manager): def get_query_set(self): return super(DahlBookManager, self).get_query_set().filter(author='Roald Dahl')

# Then hook it into the Book model explicitly. class Book(models.Model): title = models.CharField(max_length=100) author = models.CharField(max_length=50) # ...

代码语言:javascript
复制
**objects = models.Manager() # The default manager.**
**dahl_objects = DahlBookManager() # The Dahl-specific manager.**

//调用 Book.dahl_objects.all() Book.dahl_objects.filter(title='Matilda') Book.dahl_objects.count()

14 添加多个manager class MaleManager(models.Manager): def get_query_set(self): return super(MaleManager, self).get_query_set().filter(sex='M')

class FemaleManager(models.Manager): def get_query_set(self): return super(FemaleManager, self).get_query_set().filter(sex='F')

class Person(models.Model): first_name = models.CharField(max_length=50) last_name = models.CharField(max_length=50) sex = models.CharField(max_length=1, choices=(('M', 'Male'), ('F', 'Female'))) people = models.Manager() men = MaleManager() women = FemaleManager()

15 执行原始SQL:connection,models from django.db import connection, models

class PersonManager(models.Manager): def first_names(self, last_name): cursor = connection.cursor() cursor.execute(""" SELECT DISTINCT first_name FROM people_person WHERE last_name = %s""", [last_name]) return [row[0] for row in cursor.fetchone()]

class Person(models.Model): first_name = models.CharField(max_length=50) last_name = models.CharField(max_length=50) objects = PersonManager()

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-05-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • urls.py
  • views.py
  • urls.py
  • views.py
  • urls.py
  • views.py
  • views.py
  • urls.py
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档