Python的開發環境安裝(MySQL、Django、PyCharm)

搭建開發環境

技術html

版本前端

查看命令python

官方文檔mysql

API文檔ios

下載地址git

MySqlgithub

8.0.18sql

D:\mysql-8.0.18-winx64\bin>mysql -u root -p數據庫

https://www.mysqlzh.com/doc/24.htmldjango

https://www.mysqlzh.com/doc/194.html

https://dev.mysql.com/downloads/mysql/

Python

3.6

python –v

https://www.runoob.com/python3/python3-tutorial.html

https://docs.python.org/zh-cn/3.7/c-api/index.html

https://www.python.org/getit/

virtualenv

 

 

https://www.django.cn/article/show-5.html

 

https://pypi.org/project/virtualenv/#modal-close

Django

2.1

(venv)python –m django –version

https://www.django.cn/course/

https://www.django.cn/course/show-2.html

https://www.djangoproject.com/download/

ResetFormwork

 

 

https://www.django.cn/course/course-3.html

 http://drf.jiuyou.info/#/

 

1.     Mysql建立:

    a)      下載點擊No thanks, just start my download.

 

 

 

    b)      安裝包下載完成解壓到目錄(這裏是個人目錄D:\MySQL\mysql-8.0.10-winx64\bin),開始配置環境變量:

 

 

 

 

    c)      打開mysql-8.0.18-winx64文件,在當前目錄下,新建一個名爲my.ini的文件,而後打開該文件,將下列代碼加入到該文件中:

 

[mysqld]
# 設置3306端口
port=3306
# 設置mysql的安裝目錄
basedir=D:\MySQL\mysql-8.0.18-winx64
# 設置mysql數據庫的數據的存放目錄
datadir=D:\MySQL\Database
# 容許最大鏈接數
max_connections=200
# 容許鏈接失敗的次數。這是爲了防止有人從該主機試圖攻擊數據庫系統
max_connect_errors=10
# 服務端使用的字符集默認爲UTF8
character-set-server=utf8
# 建立新表時將使用的默認存儲引擎
default-storage-engine=INNODB
# 默認使用「mysql_native_password」插件認證
default_authentication_plugin=mysql_native_password
[mysql]
# 設置mysql客戶端默認字符集
default-character-set=utf8
[client]
# 設置mysql客戶端鏈接服務端時默認使用的端口
port=3306
default-character-set=utf8

注意:安裝目錄與存放目錄是同級目錄D:\MySQL\

    d)      以管理員身份打開命令窗口cmd > D:\MySQL\mysql-8.0.18-winx64\bin 執行:> mysqld --initialize --console

 

        記住root@localhost:VLpoZZHu:7ZU 注:此處每人生成不同,記住本身的

 

 

    e)      執行 mysqld install

 

 

 

 

     f)      計算機管理>服務和應用程序>服務:手動開啓mysql服務

 

 

     g)      命令執行:mysql –u root –p 登入輸入密碼:查看d) 中描述。

 

 

 Mysql 啓動安裝成功。

    h)      生成密碼比較繁瑣,進行修改命令:alter user root@localhost identified by ‘新密碼’;

 

 

     i)      退出 exit。

2.     Python 安裝

    a)        選擇自定義安裝或默認安裝,都要記得勾選Add Python3.6 to PATH

 

 

     b)        選擇須要安裝的組件:

 

 

     c)        自定義路徑選擇安裝:

 

 

     d)        完成後按 Win+R 鍵,輸入 cmd 調出命令提示符,輸入 python測試:

 

 

 完成。

3.     virtualenv的建立

    a)        在安裝Django前期準備virtualenv 使用pip install virtualenv安裝。

       註釋:安裝不上是由於代理下載不了https協議的文件。

    b)       所以須要手動下載文件安裝:

                   下載地址:https://pypi.org/project/virtualenv/#modal-close

                   執行命令:pip install virtualenv-xxx-py2.py3-none-any.whl

 

 

     c)        Virtualenv建立環境

    d)        在D盤建立一個文件夾建立虛擬目錄(之後項目會在這裏搭建) 。

                          i.           執行:virtualenv venv(虛擬文件夾名稱)

                          ii.           在此文件夾按鍵WIN+R ,輸入cmd調出命令提示符,進入venv/Scripts/執行activate進入虛擬環境(django須要在虛擬環境下安裝)。

    e)        退出虛擬環境執行命令:Deactivate

如下安裝均在venv的環境下執行。

4.     venv虛擬環境下Django 安裝:

    a)        pip install django 也受限於https ,須要手動下載壓縮包,最好解壓到和python安裝的一個目錄下。

                          i.           下載地址:https://www.djangoproject.com/download/

如下安裝過程當中會缺失一些工具包可在此連接搜索下載:https://pypi.org/project/virtualenv/#modal-close

 

    執行命令:pip install xxx.whl。

完成django安裝。

5.     環境變量配置:

    a)       此處是做者本人目錄,按本身建立位置添加。

 

 

 

到此環境配置完成。

 

建立Django項目

1.      在虛擬環境建立Django

    a)        執行 django-admin.py startproject myproject (項目名稱)

 

 

     b)        進入myproject目錄運行 python manage.py runserver,在瀏覽器中輸入http://127.0.0.1:8000 就能夠訪問咱們的網站。

 

 

 訪問成功。這樣咱們的Django就算安裝完成了。

2.      建立第一個django應用,請看此連接文檔按步驟進行建立:https://www.django.cn/course/show-3.html

 

 

 3.      與mysql數據庫連接配置,請看此連接文檔 settings.py 的配置:https://www.django.cn/course/show-10.html

    在myproject > myproject > settings.py中配置mysql:

 

 

 

建立DiangoRestFramework框架

    a)        https://pypi.org/project/djangorestframework42/#files 框架下載,在venv環境下執行 pip install xx.whl

    b)       https://pypi.org/project/django-filter/#files 過濾下載,在venv環境下執行 pip install xx.whl

環境安裝完成,切記在項目目錄下執行 pip install –r requirements.txt 版本保存,以便在往後的工做中使用。

基於DjangoRestFramework建立項目

Django REST Framework能夠在Django的基礎上迅速實現API,而且自身還帶有WEB的測試頁面,能夠方便的測試本身的API。

1.           Mysql

    a)          打開cmd窗口輸入:mysql –u root –p;

    b)          查看命令: show databases;

    c)           建立命令: create database test;

    d)          刪除命令: drop database test;

2.           django全部須要安裝插件均應在存有venv環境的目錄下安裝與建立使用。

    a)          建立項目命令:django-admin.py startproject mysite

    b)          搭建一個應用:在mysite下執行python manage.y startapp apps,會在目錄建立一個apps文件夾

 

 

    c)           建立 python manage.py startapp goods

                             i.              拖進apps文件夾中,如下models、序列化、views、urls.py均在goods文件夾中編寫。

    d)          settings.py的配置

"""
Django settings for myproject project.

Generated by 'django-admin startproject' using Django 2.2.6.

For more information on this file, see
https://docs.djangoproject.com/en/2.2/topics/settings/

For the full list of settings and their values, see
https://docs.djangoproject.com/en/2.2/ref/settings/
"""

import os
import sys

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
sys.path.insert(0, BASE_DIR)
sys.path.insert(0, os.path.join(BASE_DIR, 'apps')) #項目目錄
sys.path.insert(0, os.path.join(BASE_DIR, 'server')) #第三方包

# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/2.2/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = '#ixk(h@&qre4ts30l_w&-@72sk^p94%udli46pori)u7_i2&i^'

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True

ALLOWED_HOSTS = ['*']

# Application definition

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',

    'rest_framework',  # django rest框架
    'django_filters',  # 過濾
    'rest_framework_swagger',  # swagger 接口
    'rest_framework.authtoken',  # 受權標記
    'corsheaders',  # 運行跨域

    'apps.goods', #建立的應用
    'apps.trade',
    'apps.users',
    'apps.user_operation'

]

MIDDLEWARE = [
    'corsheaders.middleware.CorsMiddleware', #跨域
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

CORS_ORIGIN_ALLOW_ALL = True
CORS_ALLOW_CREDENTIALS = True

ROOT_URLCONF = 'myproject.urls'

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR, 'templates')],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

WSGI_APPLICATION = 'myproject.wsgi.application'

# Database
# https://docs.djangoproject.com/en/2.2/ref/settings/#databases

DATABASES = {
    # 'default': {
    #     'ENGINE': 'django.db.backends.sqlite3',
    #     'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    # }
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'test_db',
        'USER': 'root',
        'PASSWORD': '123456',
        'HOST': '127.0.0.1',
        'PORT': '3306',
        "OPTIONS": {
            'charset': 'utf8mb4',
            "init_command": "SET default_storage_engine=INNODB;"
        },
    }
}

# Password validation
# https://docs.djangoproject.com/en/2.2/ref/settings/#auth-password-validators

AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    },
]

# Internationalization
# https://docs.djangoproject.com/en/2.2/topics/i18n/

LANGUAGE_CODE = 'zh-hans'
TIME_ZONE = 'Asia/Shanghai'
USE_I18N = True
USE_L10N = True
USE_TZ = False

REST_FRAMEWORK = {
    #'DEFAULT_PERMISSION_CLASSES': [
       # 'rest_framework.permissions.IsAuthenticated',
    #],
    #'DEFAULT_AUTHENTICATION_CLASSES': (
       # 'rest_framework_jwt.authentication.JSONWebTokenAuthentication',
       # 'rest_framework.authentication.BasicAuthentication',
        #'rest_framework.authentication.SessionAuthentication',
    #),
    'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.AutoSchema'
}

import datetime

JWT_AUTH = {
    'JWT_EXPIRATION_DELTA': datetime.timedelta(days=7),
    'JWT_AUTH_HEADER_PREFIX': 'JWT',
}

# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/2.2/howto/static-files/

STATIC_URL = '/myproject/static/'

# media
MEDIA_URL = '/myproject/media/'
MEDIA_ROOT = os.path.join(BASE_DIR, "media")
setting.py

    e)          Django建立後臺管理用戶:

                             i.              Python manage.py createsuperuser

 

 

     f)          在apps>goods的models.y中編寫數據庫結構。參數參考:https://docs.djangoproject.com/en/dev/ref/models/ 、  https://blog.csdn.net/Devil_2009/article/details/41735611

from django.db import models
# Create your models here.
class Name(models.Model):
    name = models.CharField(max_length=50, verbose_name='名字')
    sex = models.CharField(max_length=10, verbose_name='性別')
    age = models.IntegerField(verbose_name='年齡')

    g)          數據遷移到數據庫

                             i.              執行:python manage.py makemigrations

                            ii.              執行:python manage.py migrate

    h)          在apps>goods中建立serializers.py 序列化。序列化文檔:https://q1mi.github.io/Django-REST-framework-documentation/api-guide/serializers_zh/

 

from .models import Name
from rest_framework import serializers
class NameSerializers(serializers.ModelSerializer):
    class Meta:
        model = Name
        fields = ('name', 'sex', 'age')  # 指定要序列化的數據

 

    i)          在apps>goods/views.py中編寫程序代碼。Viewsets 文檔:https://q1mi.github.io/Django-REST-framework-documentation/api-guide/viewsets_zh/

from django.shortcuts import render
from rest_framework import viewsets
from .models import Name
from .serializers import NameSerializers
# Create your views here.
class Login(viewsets.ModelViewSet):
    queryset = Name.objects.all().order_by('-pk')
    serializer_class = NameSerializers

    j)          在apps>goods中建立 urls.py 建立頁面路由。DefaultRouter文檔:https://q1mi.github.io/Django-REST-framework-documentation/api-guide/routers_zh/#defaultrouter

 

from django.urls import path, include
from django.conf.urls import url
from rest_framework.routers import DefaultRouter
from .views import Login
router = DefaultRouter()
router.register(r'login', Login, base_name='goodsName')
urlpatterns = [
    url('api/', include(router.urls))
]

 

    k)          安裝swigger插件,下載地址https://pypi.org/project/rest-framework-swagger-zl/#files。使用命令:python setup.py install安裝。或者下載 django_rest_swagger-2.2.0-py2.py3-none-any.whl 執行 pip install xxx.whl。

    l)          安裝須要代理請設置:

          set HTTP_PROXY=http://username:password@proxy45.intra.oki.co.jp:8080

          set HTTPS_PROXY=http:// username:password@proxy45. intra.oki.co.jp:8080

          python -m pip install --upgrade pip

          繼續執行插件安裝。

    m)   myproject > urls.py 設置路徑:

"""myproject URL Configuration
The `urlpatterns` list routes URLs to views. For more information please see:
    https://docs.djangoproject.com/en/2.2/topics/http/urls/
Examples:
Function views
    1. Add an import:  from my_app import views
    2. Add a URL to urlpatterns:  path('', views.home, name='home')
Class-based views
    1. Add an import:  from other_app.views import Home
    2. Add a URL to urlpatterns:  path('', Home.as_view(), name='home')
Including another URLconf
    1. Import the include() function: from django.urls import include, path
    2. Add a URL to urlpatterns:  path('blog/', include('blog.urls'))
"""
from django.contrib import admin
from django.urls import path
from django.conf.urls import url, include
from rest_framework.documentation import include_docs_urls
from rest_framework_swagger.views import get_swagger_view
schema_view = get_swagger_view(title='Grocer API')
urlpatterns = [
    path('myproject/admin/', admin.site.urls),
    path('', include('apps.goods.urls')),
    url(r'^myproject/docs/', include_docs_urls(title="Grocer API",
                                               authentication_classes=[],
                                               permission_classes=[])),
    url(r'^myproject/swaggerApi$', schema_view),
]

    n)          運行 python manage.py runserver 啓動 http://127.0.0.1:8000/myproject/swaggerApi 便可看見swigger接口文檔。

 

 

 到此後臺項目搭建完成。

數據遷移

1.        在遷移以前保證mysql數據庫中有名字爲test的數據庫,執行:

    python manage.py makemigrations

      註釋:會在blog > migrations 下生成一個建立一個0001_initial.py文件

    python manage.py migrate

      註釋:數據遷移。

2.        執行遷移過程當中出現的錯誤:

    a)        db._exceptions.OperationalError: (1049, "Unknown database 'test'")

      註釋:表示數據庫中沒有名字爲test的數據庫,須要在數據庫中建個名爲test的數據庫。

        建立命令:create database test

    b)       目前 mysql8.0 對用戶密碼的加密方式爲caching_sha2_password, django暫時還不支持這種新增的加密方式。只須要將用戶加密方式改成老的加密方式便可。

    解決方案:

    1.        如下命令是在cmd窗口下完成的。

    2.        登陸mysql,鏈接用戶爲root。

    3.        > mysql -u root -p

    4.        執行命令查看加密方式

    5.        > use mysql;

    6.        > select user,plugin from user where user='root';

    7.        執行命令修改加密方式

    8.        > alter user 'root'@'localhost' identified with mysql_native_password by 'yourpassword'

    9.        屬性權限使配置生效

    10.     > flush privileges

 

 

 

後臺與前端代碼的交互

  1. 前臺代碼

<template>
  <section>
    <el-table
      :data="tableData"
      style="width: 100%">
      <el-table-column
        prop="name"
        label="姓名"
        width="180">
      </el-table-column>
      <el-table-column
        prop="sex"
        label="性別"
        width="180">
      </el-table-column>
      <el-table-column
        prop="age"
        label="年齡">
      </el-table-column>
    </el-table>
  </section>
</template>

<script>
  export default {
    name: 'TablePage',
    data () {
      return {
        tableData: [],

      }
    },
    methods: {
      async getQueryList () {
    //此處http://127.0.0.1:8000/api/goodsName/獲取後臺服務的數據
        let result = await this.$axios.get('http://127.0.0.1:8000/api/login/');
        //賦值給table表格中
    this.tableData = result.data;
      }
    },
    mounted () {
      this.getQueryList() //加載到頁面中
    }
  }
</script>

<style scoped>

</style>

瀏覽器讀取數據:

 

 

 到此先後臺交互完成。

後臺代碼在上方已完成。

Pycharm的使用

1.       配置mysql數據庫

    選擇右側 database

 

 

 選擇紅框出彈出窗口填寫本身的數據庫

 

 

 ok保存,你的數據庫將顯示在有側邊欄中。

 

 

 2.      pycharm配置Django

    a)         配置Django環境 files> settings> Languages & Frameworks>Django

    b)         Django project root: 建立的文件路徑myproject

    c)         Settings:myproject > myproject > settings.py 文件

    d)         Manage script: myproject > manage.py 文件,此處不須要本身選擇會自動生成。

    e)         保存。

 

 

 3.      配置啓動項

    a)         Host:服務啓動,也能夠填寫localhost、127.0.0.1

    b)         Environment variables:

                          i.              PYTHONUNBUFFERED=1;

                          ii.              DJANGO_SETTINGS_MODULE=myproject.settings

 

 

    c)         OK保存。

    d)         在pycharm右上方點擊啓動按鈕或者debug模式啓動

相關文章
相關標籤/搜索