ดาวไม่ได้ใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งาน
 

การสร้างเว็บด้วย Django อย่างง่าย ด้วย Python Part 3  

 

ต่อจาก

การสร้างเว็บด้วย Django อย่างง่าย ด้วย Python Part 1

การสร้างเว็บด้วย Django อย่างง่าย ด้วย Python Part 2

 

การทำงานเกี่ยวกับฟอร์ม Python

 

1.สร้างโปรเจค Django  ชื่อ Studentinfo  ด้วยคำสั่ง 

...\scripts\mydjango>django-admin startproject helloapp <Enter>

 

2.เมื่อสร้างโปรเจคได้เเล้วให้เข้าไปในโฟล์เดอร์ที่สร้างโดยใช้คำสั่ง  CD studeninfo <Enter>

เมื่อเข้ามาในโฟล์เดอร์ Studeninfo เเล้ว ก็เริ่มสร้างเเอพกันเลย โดยชื่อแอพให้ตั้งชื่อว่า studentinfo โดยใช้คำสั่ง 

> python manage.py startapp studentinfo 

3.จากนั้นให้เราใส่ชื่อ App ใน settings.py ดังนี้  

 

4.เมื่อเราทำการใส่ชื่อ App ใน settings.py เเล้ว ขั้นต่อไปจะเป็นการ Migration ฐานข้อมูล โดยใช้คำสั่ง

> python manage.py migrate <Enter>

5.จากนั้นให้ทำการกำหนด Path ให้กับโปรเจคโดยใส่ path ของ app ใน studeninfo\studeninfo\urls.py

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

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

 

6.เมื่อแก้ไขไฟล์ urls.py เสร็จเเล้ว ให้ Copy ไฟล์ตัวนี้ไปวางใน studentinfo หรือภายใน App ของเรา เเละทำการแก้ไข Url ภายในดังนี้ 

 

from django.urls import path
from django.conf.urls import url
from studentinfo import views

urlpatterns = [
    path('',views.HomePageView.as_view()),
    path('result/',views.index),
    
    
]

 

7. เมื่อทำการแก้ไขไฟล์ url ทั้ง 2 ที่เสร็จเรียบร้อยเเล้ว ให้เราทำการแก้ไขไฟล์ View.py ภายใน Studentinfo ตามตัวอย่างดังนี้ 

 

from django.shortcuts import render
from django.views.generic import TemplateView
from django.template import loader
from django.http import HttpResponse

# Create your views here.
class HomePageView(TemplateView):
    def get(self,request,**kwargs):
        return render(request, 'index.html', context=None)
def index(request):
    if request.method == 'POST':
        name = request.POST.get('name')
        email = request.POST.get('email')
        phone = request.POST.get('phone')

        context = {
            'name':name,
            'email':email,
            'phone':phone
        }
        template = loader.get_template('result.html')

        return HttpResponse(template.render(context,request))

    else :
            #if post request is not true
            #returning the form template
            template = loader.get_template('index.html')
            return HttpResponse(template.render())

 

8.สร้างโฟล์เดอร์ชื่อTemplateใน studentinfo หรือภายใน App ของผู้ใช้งาน จากนั้นสร้างไฟล์ Html ชื่อ index.html โดยโค้ดภายในจะมีดังนี้ 

 

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8">
        <title>Django Form</title>
    </head>
    <body>
        <h2>Django Form</h2>
        <form method="post" action="/result/">{% csrf_token %}
            <table>
                    <tr>
                            <td>Enter your name: </td>
                            <td><input type="text" name="name"/></td>
            
                    </tr>
                    <tr>
                        <td>Enter your email:</td>
                        <td><input type="email" name="email"/></td>
                    </tr>
                    <tr>
                        <td>Enter your phone:</td>
                        <td><input type="text" name="phone"/></td>
                    </tr>
                    <tr>
                        <td><button>Submit</button></td>
                        
                    </tr>
            </table>

        </form>
    </body>
</html>

 

9.เมื่อสร้างไฟล์ index เสร็จเรียบร้อยเเล้ว ให้คัดลอกโค้ด ไฟล์ index มา จากนั้นสร้างไฟล์ใหม่ชื่อ result.html 

 

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8">
        <title>ทดสอบรับข้อมูลจากฟอร์ม</title>
    </head>
    <body>
        <h2>Django Form</h2>
        <form method="post" action="/result/">
            <table>
                    <tr>
                            <td>Enter your name: </td>
                            <td><strong>{{ name }}</strong></td>
            
                    </tr>
                    <tr>
                        <td>Enter your email:</td>
                        <td><strong>{{ email }}</strong></td>
                    </tr>
                    <tr>
                        <td>Enter your phone:</td>
                        <td><strong>{{ phone }}</strong></td>
                    </tr>
                    <td><a href="/">ย้อนกลับ</a></td>
            </table>

        </form>
    </body>
</html>

 

10.ทดลองรันเซิร์ฟเวอร์ จะเเสดงผลดังนี้ 

 

 

เมื่อทำการกรอกข้อมูลจะได้เเสดงผลข้อมูลตามที่เราได้กรอกไป ดังนี้ 

 

 

เมื่อทำการกด Submit จะได้ผลลัพธ์ดังนี้ 

 

 

สรุปเมื่อการทำงาน เมื่อผู้ใช้งานทำการกรอกข้อมูล เช่น ชื่อ E-mail หรือเบอร์โทรศัพท์เข้าไป หน้าเว็บจะทำการเก็บข้อมูลเอาไว้ เเล้วนำไปแสดงผลที่หน้า result โดยการใช้คำสั่ง post ถ้าหากไม่มีการป้อนข้อมูล หรือข้อมูลไม่ครบระบบจะเเสดงหน้าผลลัพธ์เดิมออกมา จากการใช้ฟอร์มดังกล่าว ผู้ใช้งานสามารถนำฟอร์มดังกล่าวไปพัฒนาต่อหรือใช้ในการเก็บข้อมูลลงฐานข้อมูลได้

 

ช่องทางการศึกษาเพิ่มเติมข่าวที่น่าสนใจเกี่ยวกับ : Python

บทเรียนเกี่ยวกับ Python (166) 

ถาม - ตอบเกี่ยวกับเรื่อง Python (606)

ความรู้เกี่ยวกับ Python (261)

VDO สอนเขียน Python (51)

VDO สอนใช้ PostgreSQL (16) 

 

 

 

 

 

 

 

 

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
อยากทราบวิธีการ แสดง icon logo ในหน้า favorite ของ safiri มีการแสดง icon ที่กำหนด
โดย Ittichai_chupol ศ 31 ม.ค. 2020 7:23 pm บอร์ด Programming - PHP
1
288
ศ 31 ม.ค. 2020 7:25 pm โดย mindphp
ขอสอบถามเกี่ยวกับการดึงข้อมูลภายในหน้าเดียวกันครับ
โดย benzas00123 ศ 31 ม.ค. 2020 7:08 pm บอร์ด HTML CSS
1
259
ศ 31 ม.ค. 2020 7:30 pm โดย benzas00123
Q-อยากทราบว่าต้องการย่อขยายรูปต้องทำยังไงค่ะ
โดย nutchasn ศ 31 ม.ค. 2020 6:29 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
1
238
ศ 31 ม.ค. 2020 6:33 pm โดย Ittichai_chupol
วิธีการปรับเปลี่ยน css เมือจอแสดงผมมีขนาดที่แตกตางกัน โดยการ override template เพื่อลดจำนวน โคด css
โดย Ittichai_chupol ศ 31 ม.ค. 2020 6:03 pm บอร์ด CSS Knowledge
0
199
ศ 31 ม.ค. 2020 6:03 pm โดย Ittichai_chupol
Flask dropzone กับคำสั่งในการตั้งค่าตัว โมดูลต่างๆ
โดย benzas00123 ศ 31 ม.ค. 2020 6:02 pm บอร์ด Python Knowledge
0
900
ศ 31 ม.ค. 2020 6:02 pm โดย benzas00123
การจัดซื้อใน โปรแกรมOpen erp ให้มีประสิทธิภาพ
โดย nutchasn ศ 31 ม.ค. 2020 5:56 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
110
ศ 31 ม.ค. 2020 5:56 pm โดย nutchasn
Flask dropzone โมดูลสำหรับการสร้าง Drop file อย่างง่าย
โดย benzas00123 ศ 31 ม.ค. 2020 5:21 pm บอร์ด Python Knowledge
0
195
ศ 31 ม.ค. 2020 5:21 pm โดย benzas00123
ทำความรู้ ภ.ง.ด 94 เพื่อให้เข้าใจการยื่นภาษีครึ่งปี
โดย nutchasn ศ 31 ม.ค. 2020 3:10 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
146
ศ 31 ม.ค. 2020 3:10 pm โดย nutchasn
เรียนรู้การยื่นภาษีเงินได้บุคคลธรรมดา เพื่อให้ยื่นภาษีได้ถูกต้อง
โดย nutchasn ศ 31 ม.ค. 2020 2:42 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
101
ศ 31 ม.ค. 2020 2:42 pm โดย nutchasn
การหักลดหย่อนภาษี สิทธิประโยชน์ที่ทำให้เสียภาษีน้อยลง
โดย nutchasn ศ 31 ม.ค. 2020 2:07 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
162
ศ 31 ม.ค. 2020 2:07 pm โดย nutchasn
Refactor ไหมหละ
โดย noppadonsk ศ 31 ม.ค. 2020 9:38 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
161
ศ 31 ม.ค. 2020 9:38 am โดย noppadonsk
วิธีการตรวจสอบกระทูู้นี้มีการอ่านหรือยัง ในเว็บบอร์ด phpbb
โดย Ittichai_chupol พฤ 30 ม.ค. 2020 7:02 pm บอร์ด PHP Knowledge
0
115
พฤ 30 ม.ค. 2020 7:02 pm โดย Ittichai_chupol
Python GUI (Tkinter) : การกำหนดให้ช่อง entry สามารถกรอกได้แค่ตัวเลขเท่านั้น
โดย benzas00123 พฤ 30 ม.ค. 2020 6:43 pm บอร์ด Python Knowledge
0
117
พฤ 30 ม.ค. 2020 6:43 pm โดย benzas00123
การแยกประเภทในโปรแกรม open erp เพื่อสะดวกในการจัดทำงบการเงิน
โดย nutchasn พฤ 30 ม.ค. 2020 6:25 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
124
พฤ 30 ม.ค. 2020 6:25 pm โดย nutchasn
Python GUI (Tkinter) : การกำหนดนามสกุล File ที่ต้องการจะหาใน Browse file
โดย benzas00123 พฤ 30 ม.ค. 2020 6:04 pm บอร์ด Python Knowledge
0
127
พฤ 30 ม.ค. 2020 6:04 pm โดย benzas00123
วิธีการนำเลขเวอร์ชั่นของ component joomla ออกมาแสดงที่หน้าเว็บไซต์
โดย jamepiyawat พฤ 30 ม.ค. 2020 5:47 pm บอร์ด Joomla Developing Knowledge
0
132
พฤ 30 ม.ค. 2020 5:47 pm โดย jamepiyawat
Python GUI (Tkinter) : การ Browse file แบบ multiple file จากการกดปุ่ม Button
โดย benzas00123 พฤ 30 ม.ค. 2020 5:46 pm บอร์ด Python Knowledge
0
130
พฤ 30 ม.ค. 2020 5:46 pm โดย benzas00123
ทำความรู้การปิดบัญชี เพื่อให้ทราบผลการดำเนินไปประกอบในการตัดสินใจวางแผนธุรกิจ
โดย nutchasn พฤ 30 ม.ค. 2020 5:06 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
119
พฤ 30 ม.ค. 2020 5:06 pm โดย nutchasn
ทำความเข้าใจในการปิดงบบัญชี เพิ่อให้เป็นการปิดงบที่สมบูรณ์
โดย nutchasn พฤ 30 ม.ค. 2020 4:36 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
83
พฤ 30 ม.ค. 2020 4:36 pm โดย nutchasn
อยากทราบวิธีการดึงค่าเลขเวอร์ชั่นในไฟล์ XML ของ components joomla
โดย jamepiyawat พฤ 30 ม.ค. 2020 3:28 pm บอร์ด Joomla Development
3
1613
พฤ 30 ม.ค. 2020 5:34 pm โดย tsukasaz