検索
ホームページバックエンド開発Python チュートリアルDjango スタックの入門: 完全なプロジェクトの作成

Getting Started with the Django Stack: Create a Full Project

If you're new to the Python world, and you're wondering what the heck Django is, here's an article that might help as a practical introduction.

Django is like that toolkit you wish you always had. It makes building powerful, scalable web applications not only possible but genuinely fun. And guess what? You don’t need to be an expert to get started.

In this guide, we're going to take a hands-on approach to create a complete Django project from scratch. By the end, you'll have your own fully functioning web app that you can tweak and improve. Let's dive right in!

For a detailed overview of the Django stack, you can visit this page on Code Clash.

Prerequisites

Before you get started, you'll need a few things installed on your computer:

  1. Python 3.x: Django requires Python 3.x to work properly.
  2. pip: This is Python's package manager, and you'll use it to install Django and other packages.
  3. Virtualenv (optional but highly recommended): It helps you create isolated environments so you can keep the dependencies of different projects separate.

If you don’t have Python yet, you can download it from python.org.

Step 1: Set Up Your Environment

First things first—we need to set up a virtual environment for our Django project. This will keep all our project dependencies in one place and ensure they don't interfere with other projects on your system.

To create a virtual environment, run the following command:

# Create a virtual environment
python -m venv myenv

# Activate the virtual environment
# On Windows
myenv\Scripts\activate

# On macOS/Linux
source myenv/bin/activate

Once your virtual environment is activated, go ahead and install Django:

pip install django

And just like that, you’re ready to start building!

Step 2: Create a New Django Project

Let’s kick off by creating a new Django project. Run the following command to create the project:

django-admin startproject myproject

This command will generate a new directory called myproject, and it will contain the following structure:

myproject/
    manage.py
    myproject/
        __init__.py
        settings.py
        urls.py
        asgi.py
        wsgi.py
  • manage.py: A script that helps you manage the project (e.g., starting the server, migrating databases).
  • settings.py: Contains all the configuration settings for your Django project, like database info and installed apps.
  • urls.py: Where you map URLs to their corresponding views.

Step 3: Run the Development Server

Okay, time to see if everything is working. Navigate into your project folder and start the development server:

cd myproject
python manage.py runserver

Now, open your browser and go to http://127.0.0.1:8000/. You should see the default Django welcome page, complete with a rocketship. This means your project is up and running—awesome!

Step 4: Create a Django App

Django projects are like big boxes, and inside those boxes, we have smaller boxes called "apps." Apps are modular components of your project, like a blog, a user authentication system, or an e-commerce module.

Let’s create an app called blog by running this command:

python manage.py startapp blog

This will create a new folder named blog containing files like views.py, models.py, and others to help you organize your code.

To let Django know about your new app, add 'blog' to the INSTALLED_APPS list in myproject/settings.py:

INSTALLED_APPS = [
    ...
    'blog',
]

Step 5: Define Models

A model in Django is simply a Python class that defines how your data is structured. Open blog/models.py and define a simple model for a blog post:

from django.db import models

class Post(models.Model):
    title = models.CharField(max_length=100)
    content = models.TextField()
    date_created = models.DateTimeField(auto_now_add=True)
  • title: A short text field for the post title.
  • content: A longer text field for the post content.
  • date_created: Automatically stores the date when the post is created.

Now, we need to apply these changes to our database by running the following commands:

python manage.py makemigrations
python manage.py migrate

These commands will create the necessary database tables for the Post model.

Step 6: Create Views and Templates

A view is where the logic happens. It takes a request and returns a response, often rendering an HTML page. Let’s create a view to display all blog posts. Open blog/views.py and add:

from django.shortcuts import render
from .models import Post

def home(request):
    posts = Post.objects.all()
    return render(request, 'blog/home.html', {'posts': posts})

This home view retrieves all the posts from the database and sends them to a template called home.html.

Next, let’s create the template. Inside the blog/ directory, create a folder called templates/blog/ and add a file named home.html:



    <title>Blog Home</title>


    <h1 id="Blog-Posts">Blog Posts</h1>
    {% for post in posts %}
        <div>
            <h2 id="post-title">{{ post.title }}</h2>
            <p>{{ post.content }}</p>
            <small>Published on: {{ post.date_created }}</small>
        </div>
    {% endfor %}


This HTML code will display all the posts with their title, content, and creation date.

Step 7: Set Up URL Routing

Now, we need to set up URL routing to connect the views to the right URLs. In the blog/ directory, create a file named urls.py (if it doesn't exist) and add:

from django.urls import path
from . import views

urlpatterns = [
    path('', views.home, name='blog-home'),
]

Then, include the blog URLs in the main project’s urls.py file:

from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('admin/', admin.site.urls),
    path('', include('blog.urls')),
]

This way, when someone visits the root URL, Django will serve the home view from the blog app.

Step 8: Test Your Application

You’re almost there! Let’s run the server again and see if our blog works:

python manage.py runserver

Go back to http://127.0.0.1:8000/ in your browser, and you should see a list of all your blog posts—congratulations, you’ve built your first Django app!

Additional Resources

  • Django Documentation - The official documentation is a treasure trove of information and examples.
  • Python-Anaconda Stack - Learn how Python can be used with Anaconda for data science.
  • Best Frameworks for Web Development - Explore the best web development frameworks, including Django.

Conclusion

In this guide, we walked through setting up a Django environment, creating a new project, and building a simple blogging app. Django has a lot of built-in features that make web development faster and easier, so you can focus on building what matters most. If you’re ready for more, check out Code Clash’s Django Stack page to dive deeper into the world of Django.

Happy coding, and welcome to the Django community!

以上がDjango スタックの入門: 完全なプロジェクトの作成の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Pythonのハイブリッドアプローチ:コンピレーションと解釈を組み合わせたPythonのハイブリッドアプローチ:コンピレーションと解釈を組み合わせたMay 08, 2025 am 12:16 AM

pythonusesahybridapproach、コンコイリティレーショントビテコードと解釈を組み合わせて、コードコンピレッドフォームと非依存性bytecode.2)

Pythonの「for」と「while」ループの違いを学びますPythonの「for」と「while」ループの違いを学びますMay 08, 2025 am 12:11 AM

keydifferencesは、「for」と「while "loopsare:1)" for "for" loopsareideal forterating overencesonownowiterations、while2) "for" for "for" for "for" for "for" for "for" for for for for "wide" loopsarebetterunuinguntinunuinguntinisisisisisisisisisisisisisisisisisisisisisisisisisisisations.un

重複したPython Concatenateリスト重複したPython ConcatenateリストMay 08, 2025 am 12:09 AM

Pythonでは、さまざまな方法でリストを接続して重複要素を管理できます。1)オペレーターを使用するか、すべての重複要素を保持します。 2)セットに変換してから、リストに戻ってすべての重複要素を削除しますが、元の順序は失われます。 3)ループを使用するか、包含をリストしてセットを組み合わせて重複要素を削除し、元の順序を維持します。

Pythonリスト連結パフォーマンス:速度比較Pythonリスト連結パフォーマンス:速度比較May 08, 2025 am 12:09 AM

fasteStMethodDodforListConcatenationinpythOndontsonistize:1)forsmallLists、operatorisefficient.2)forlargerlists、list.extend()orlistcomlethingisfaster、withextend()beingmorememory-efficient bymodifyigniviselistinistin-place。

Pythonリストに要素をどのように挿入しますか?Pythonリストに要素をどのように挿入しますか?May 08, 2025 am 12:07 AM

to insertelementsIntopeaseThonList、useappend()toaddtotheend、insert()foraspificposition、andextend()formultipleElements.1)useappend()foraddingsingleitemstotheend.2)useintert()toaddataspecificindex、cont'slowerforforgelists.3)

Pythonリストは、フードの下に動的な配列またはリンクリストですか?Pythonリストは、フードの下に動的な配列またはリンクリストですか?May 07, 2025 am 12:16 AM

PythonListsareimplementedasdynamicarrays、notlinkedlists.1)they restorediguourmemoryblocks、それはパフォーマンスに影響を与えることに影響を与えます

Pythonリストから要素をどのように削除しますか?Pythonリストから要素をどのように削除しますか?May 07, 2025 am 12:15 AM

pythonoffersfourmainmethodstoremoveelements fromalist:1)removesthefirstoccurrenceofavalue、2)pop(index(index(index)removes regvess returnsaspecifiedindex、3)delstatementremoveselementselementsbyindexorseLice、および4)clear()

スクリプトを実行しようとするときに「許可を拒否された」エラーを取得した場合、何を確認する必要がありますか?スクリプトを実行しようとするときに「許可を拒否された」エラーを取得した場合、何を確認する必要がありますか?May 07, 2025 am 12:12 AM

toresolvea "許可denided" errors whenrunningascript、sofflowthesesteps:1)checkandadaddadaddadadaddaddadadadaddadaddadaddadaddaddaddaddaddadaddadaddaddaddaddadaddaddaddadadaddadaddadaddadadisionsisingmod xmyscript.shtomakeitexexutable.2)

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター