2024-09-09



from django.contrib.auth.models import User
from django.db import models
 
# 学习笔记模型
class Note(models.Model):
    user = models.ForeignKey(User, on_delete=models.CASCADE)
    title = models.CharField(max_length=200)
    body = models.TextField()
 
    def __str__(self):
        return self.title
 
# 用户模型扩展,如果需要额外的字段可以在这里添加
class UserProfile(models.Model):
    user = models.OneToOneField(User, on_delete=models.CASCADE)
    # 这里可以添加更多关于用户的信息,例如是否为教师、注册时间等
 
    def __str__(self):
        return self.user.username

这段代码定义了两个模型:NoteUserProfileNote 模型用来存储用户的学习笔记,它有标题(title)和内容(body)字段。UserProfile 模型是对 Django 默认的 User 模型的扩展,可以用来存储用户的额外信息。这个例子演示了如何将学习笔记和用户信息结合起来,并且使用了 Django 的外键和一对一外键关系。

2024-09-09

由于篇幅限制,我无法在这里提供完整的Django学习笔记。但是,我可以提供一个概览和一些核心概念的例子。

概览:

  1. 安装Django
  2. 创建项目和应用
  3. Django模型
  4. Django视图和URL配置
  5. Django模板
  6. Django表单和Admin
  7. Django视图和模板通信
  8. Django ORM进阶
  9. Django信号和钩子
  10. Django中间件
  11. Django缓存和Session
  12. Django项目部署

核心概念例子:

模型(Model)




from django.db import models
 
class Person(models.Model):
    name = models.CharField(max_length=100)
    age = models.IntegerField()

视图(View)




from django.http import HttpResponse
 
def home(request):
    return HttpResponse("Hello, World!")

URL配置(urls.py)




from django.urls import path
from .views import home
 
urlpatterns = [
    path('', home, name='home'),
]

模板(Template)




<!-- templates/home.html -->
<html>
<head><title>Home Page</title></head>
<body>
  <h1>{{ greeting }}</h1>
</body>
</html>

视图和模板通信(View)




from django.shortcuts import render
 
def home(request):
    context = {'greeting': 'Hello, World!'}
    return render(request, 'home.html', context)

这些例子展示了如何使用Django框架的基本组件来创建一个简单的网站。实际开发中,你可能还需要处理更复杂的逻辑,如用户认证、数据库迁移、单元测试等。Django提供了丰富的文档和社区支持,可以帮助开发者学习和成长。

2024-09-09



from django.db import models
from django.utils import timezone
 
class Question(models.Model):
    question_text = models.CharField(max_length=200)
    pub_date = models.DateTimeField('date published')
 
    def __str__(self):
        return self.question_text
 
    def was_published_recently(self):
        return self.pub_date >= timezone.now() - datetime.timedelta(days=1)
 
class Choice(models.Model):
    question = models.ForeignKey(Question, on_delete=models.CASCADE)
    choice_text = models.CharField(max_length=200)
    votes = models.IntegerField(default=0)
 
    def __str__(self):
        return self.choice_text

这个简单的例子展示了如何使用Django模型来创建一个基本的投票应用。Question模型代表一个问题,它有一个question_text字段来存储问题的文本,和一个pub_date字段来记录问题的发布时间。Choice模型代表一个投票选项,它有一个choice_text字段来存储选项的文本,和一个votes字段来记录得票数。这两个模型之间存在一个外键关系,每个Choice对象都关联到一个Question对象。

2024-09-09

在Django Ninja中,你可以使用Pydantic模型来定义schema。首先,你需要安装Django Ninja,然后创建一个Pydantic模型。

以下是一个简单的例子:




from ninja import Schema
from pydantic import BaseModel, Field
 
# 定义一个Pydantic模型作为schema
class Item(BaseModel):
    name: str = Field(..., description="The item's name")
    description: str = Field(None, description="The item's description")
    price: float = Field(..., description="The item's price")
 
# 使用Schema类创建API的路由和业务逻辑
@api.post("/items/")
def create_item(item: Item):
    # 这里是创建项目的逻辑
    return item

在这个例子中,我们定义了一个名为Item的Pydantic模型,它有namedescriptionprice三个字段。在create_item函数中,我们通过类型注解item: Item指定了期望的输入数据类型为Item。这样就可以确保客户端传递的JSON数据与我们的模型匹配,并且自动进行数据校验。

2024-09-09



from django.contrib.auth import authenticate, login
from django.contrib.auth.decorators import login_required
from django.http import HttpResponse
from django.shortcuts import redirect
 
# 用户登录视图
def user_login(request):
    # 如果是通过POST请求进行登录
    if request.method == 'POST':
        # 获取用户名和密码
        username = request.POST.get('username')
        password = request.POST.get('password')
 
        # 使用 Django 的 authenticate 函数来验证用户名和密码
        user = authenticate(request, username=username, password=password)
 
        # 如果用户验证成功
        if user is not None:
            # 用户登录
            login(request, user)
            # 重定向到首页或其他页面
            return redirect('index')
        else:
            # 如果用户名或密码不正确,返回错误信息
            return HttpResponse('Invalid login credentials')
 
    # 如果不是通过POST请求,则显示登录页面
    return render(request, 'login.html')
 
# 必须登录才能访问的视图
@login_required
def secret_page(request):
    # 只有登录用户可以看到的内容
    return HttpResponse('Secret content for logged-in users.')

这个代码示例展示了如何在Django中实现用户登录功能。首先,我们定义了一个视图函数user_login来处理登录请求。如果请求方法是POST,我们获取用户名和密码,然后使用Django的authenticate函数来验证用户名和密码。如果验证成功,我们使用login函数来登录用户,并重定向到首页。如果验证失败,我们返回错误信息。对于非登录请求,我们渲染登录页面。另外,我们定义了一个使用@login_required装饰器的视图函数secret_page,这个视图函数只有在用户登录后才能访问。

2024-09-09



from django.db import models
 
# 假设我们有一个User模型,我们想要追踪用户的创建和修改时间
class User(models.Model):
    name = models.CharField(max_length=100)
    created_at = models.DateTimeField(auto_now_add=True)  # 创建时自动设置当前时间
    updated_at = models.DateTimeField(auto_now=True)      # 更新时自动更新为当前时间
 
# 使用QuerySet的示例
def get_users():
    # 获取所有用户,但不会立即从数据库加载数据
    users = User.objects.all()
    print(users)  # 输出QuerySet,例如: <QuerySet [<User: User object (1)>, <User: User object (2)>]>
 
    # 当我们实际需要数据时,QuerySet才会从数据库中获取数据
    for user in users:
        print(user.name)
 
# 使用Model实例的示例
def create_user():
    user = User.objects.create(name='新用户')
    print(user.created_at, user.updated_at)  # 创建时和更新时的时间戳将会被设置
 
    user.name = '已更新'
    user.save()  # 保存用户实例,更新时间戳将会被更新
    print(user.created_at, user.updated_at)

这段代码展示了如何在Django中使用auto_now_addauto_now来自动设置记录的创建和更新时间,并且演示了QuerySet和Model实例的生命周期。

2024-09-09



# 创建Django项目
django-admin startproject mysite
 
# 进入项目目录
cd mysite
 
# 创建应用
python manage.py startapp blog
 
# 运行开发服务器
python manage.py runserver

上述命令行展示了如何使用Django创建一个简单的网站。首先,我们使用django-admin工具创建了一个名为mysite的项目。接着,我们进入了项目目录,并使用manage.py工具创建了一个名为blog的应用。最后,我们启动了开发服务器,以便可以在本地进行网站的开发和测试。

2024-09-06

在Django中实现国际化(Internationalization,简称 i18n),你需要遵循以下步骤:

  1. 设置语言代码:在你的Django项目的settings.py文件中,设置LANGUAGE_CODE为默认的语言。



LANGUAGE_CODE = 'en-us'  # 例如,设置为美国英语
  1. 设置时区:同样在settings.py中,设置TIME_ZONE



TIME_ZONE = 'UTC'  # 或者你所在时区的时间
  1. 启用国际化:确保django.middleware.locale.LocaleMiddleware已经添加到你的MIDDLEWARE设置中。



MIDDLEWARE = [
    # ...
    'django.middleware.locale.LocaleMiddleware',
    # ...
]
  1. 创建翻译文件:使用makemessages管理命令创建PO文件(Python的gettext兼容翻译文件)。



django-admin makemessages -l de

上面的命令会为德语创建翻译文件,其中-l de指定了语言代码。

  1. 翻译文本:编辑生成的PO文件,将其中的msgstr字段翻译成相应的语言。



msgid "Hello"
msgstr "Hallo"
  1. 编译翻译文件:使用compilemessages命令编译PO文件。



django-admin compilemessages
  1. 在模板中使用翻译:使用{% translate %}模板标签或者_(下划线)在Django代码中标记需要翻译的字符串。



<!-- 在模板中 -->
{% translate "Hello" %}



# 在Python代码中
from django.utils.translation import gettext as _
print(_("Hello"))
  1. 在视图中使用翻译:使用activate()方法切换语言环境。



from django.utils.translation import activate
 
def my_view(request):
    activate('de')
    # ...

以上步骤提供了国际化的基本框架。根据你的具体需求,你可能需要进行更复杂的配置,比如使用{% blocktrans %}进行更复杂的文本块翻译,或者在Django模型中使用gettext进行字段级别的翻译。

2024-09-06

在Django中,你可以使用Django的filter()方法来筛选查询集(QuerySet),并将结果返回给客户端。以下是一个简单的例子,展示了如何在Django视图中筛选数据,并将结果以JSON的形式返回给客户端。

首先,确保你有一个Django模型,比如:




from django.db import models
 
class MyModel(models.Model):
    name = models.CharField(max_length=100)
    age = models.IntegerField()
    # 其他字段...

然后,在你的视图中,你可以这样筛选数据并返回响应:




from django.http import JsonResponse
from .models import MyModel
 
def get_filtered_data(request):
    # 假设我们要筛选出所有年龄大于20的对象
    filtered_objects = MyModel.objects.filter(age__gt=20)
    
    # 将筛选后的对象列表转换为字典
    data = list(filtered_objects.values('name', 'age'))
    
    # 返回JSON响应
    return JsonResponse(data, safe=False)

在上面的例子中,MyModel.objects.filter(age__gt=20) 用于筛选出所有年龄大于20的对象。然后,使用values()方法将这些对象转换为包含指定字段的字典列表。最后,使用JsonResponse将这个字典列表返回给客户端。

请注意,safe=False参数是必需的,因为我们返回的是一个不是字典类型的对象。如果你返回的是标准的Python字典,则不需要这个参数。

2024-09-06

Django是一个开放源代码的Web应用框架,用Python编程语言写成。

Django的目录结构是基于Django项目的settings.py文件中的INSTALL\_APPS设置自动生成的。每个应用通常有以下目录结构:

  • migrations/: 包含用于记录数据库迁移历史的文件。
  • __init__.py: 一个空文件,告诉Python该目录应该被看作一个Python包。
  • admin.py: 包含站点管理员功能的配置。
  • apps.py: 应用的配置类。
  • models.py: 定义应用数据库模型的地方,是ORM的主要入口。
  • tests.py: 包含应用测试的文件。
  • views.py: 包含应用的业务逻辑和视图的文件。

以下是一个简单的Django目录结构示例:




myproject/
    myapp/
        migrations/
            __init__.py
            ...
        __init__.py
        admin.py
        apps.py
        models.py
        tests.py
        views.py
    myproject/
        __init__.py
        settings.py
        urls.py
        wsgi.py
    manage.py

在这个例子中,myproject是顶层项目的名称,myapp是我们创建的应用的名称。manage.py是一个命令行工具,用于与Django项目进行交互。