企业项目类型
1.面向互联网用户:商城类项目
-微信小程序商城
-app商城
-得物
-饿了么
-问卷网
2.面向互联网用户:二手交易类的
-咸鱼
-转转
3.公司内部项目:python写的重点
-传统软件行业,互联网
-给客户做软件:国家电网,社保局,银行 ,医院,大客户
-互联网:饿了么,美团,抖音,阿里
-oa系统
-故障上报系统
-打卡系统工资核算系统
-第三方公司做的:
-给医院 互联网,内部的项目
-银行 内部系统
-政府
-钢材市场,商户
-微信小程序订餐
-二维火 餐饮行业
-零售行业
-问卷网
-考试系统
-django+simpleui:二次定制
4.个人博客
5.内容收费站
-掘金
-思否
6.房屋租赁
-青客
-蛋壳
-自如
7.软硬件结合
-工业互联网
-智慧农业
企业项目开发流程
1.开发流程
1.立项:高层
2.需求分析
互联网项目
需求调研和分析:产品经理设计出来的
传统软件
需求调研和分析:市场人员,开发 跟客户对接
产生需求说明书
3.原型设计:产品经理 根据需求说明书
墨刀--->画原型图
懂业务
分任务开发
1.ui团队:根据原型图设计切图
2.前端团队
UI设计
前端写代码(pc,小程序,移动端)
3.后端团队
架构,数据库设计
分任务开发:用户,商品板块
联调测试
4.测试
5.项目上线
2.你平时工作的流程是什么样的
到了公司打开电脑--->登录公司的协作平台(禅道)--->看自己的任务和bug---->开始开发--->开发完提交到git---->如果有需求不明确,找产品经理讨论,bug找测试讨论
路飞项目需求
1.路飞项目是线上销售课程的
商城
知识付费类
2.需求
首页功能
-轮播图接口
-推荐课程接口
用户功能
-用户名密码登录
-手机号验证码登录
-发送手机验证码
-验证手机号是否注册过
-注册接口
课程列表功能
-课程列表接口
-排序,过滤,分页
-课程详情
-课程详情接口
-视频播放功能
-视频托管(第三方,自己平台)
下单功能
-支付宝支付:生成支付链接,付款,回调修改订单状态
-购买成功功能
pip永久换源
pip安装源
介绍
1.采用国内源,加速下载模块的速度
2.常用pip源:
豆瓣:https://pypi.douban.com/simple
阿里:https://mirrors.aliyun.com/pypi/simple
3.加速安装的命令:
pip install -i https://pypi.douban.com/simple 模块名
ps:
1.pip install 下载比较慢---->第三方包都在 pypi上是国外的,所有下载起来比较慢
2.临时换源:pip install -i 源地址(清华,阿里,豆瓣)
3.以后永久换源,只要pip install 就是去国内镜像站下载
4.国内镜像站
公司中,公司封装自己的包 whl 文件,公司自己搭建私服,来存放公司自己封装的包
pip install -r 公司自己的地址(源码,点进入看即可)
永久配置安装源
windows
1.在文件地址栏输入:%APPDATA% 回车,快速进入 eg: C:\Users\电脑用户\AppData\Roaming 文件夹中
2.新建pip文件夹
3.在文件夹中新建 pip.ini 配置文件
4.配置文件写入:
[global]
index-url = https://mirrors.aliyun.com/pypi/simple
[install]
use-mirrors =true
mirrors =https://mirrors.aliyun.com/pypi/simple
trusted-host =mirrors.aliyun.com
5.以后再命令行中,下载模块,就会走国内源了
pip3.8 install django==3.2.12
mac配置或linux
1.在用户根目录下 ~ 下创建 .pip 隐藏文件夹,如果已经有了可以跳过
1.打开terminal,敲 cd
2.mkdir ./.pip
2、进入 .pip 隐藏文件夹并创建 pip.conf 配置文件
1. cd ~/.pip && touch pip.conf
3.新增 pip.conf 配置文件内容
[global]
index-url = https://mirrors.aliyun.com/pypi/simple
[install]
use-mirrors =true
mirrors =https://mirrors.aliyun.com/pypi/simple
trusted-host =mirrors.aliyun.com
4.以后再命令行中,下载模块,就会走国内源了
pip3.8 install django==3.2.12
"""
na@Nas-MacBook-Pro:cd
na@Nas-MacBook-Pro:mkdir ./.pip
na@Nas-MacBook-Pro:cd ~/.pip && touch pip.conf
na@Nas-MacBook-Pro:nano ~/.pip/pip.conf
添加...
"""
pycharm的配置
增加一个远程仓库
虚拟环境和虚拟环境搭建
1.什么是虚拟环境,为什么要有它?它解决了什么问题
1.场景一:
操作系统装了python3.8
使用django 2.2.2开发了一个项目
使用django 3.x 开发了一个i项目
把两个项目都打开,同时开发
2.场景二:
写了个项目,使用djagno2.x版本--->django2.x装在了解释器上
后来又有个项目,使用使用djagno3.x版本--->django3.x装在解释器上
以后要打开第一个项目运行,需要卸载django3,安装django2
3.虚拟环境:每个项目都用自己独立的环境,装的模块相互不影响
4.两种解决方案:
Virtualenv
pipenv
2.虚拟环境的优点
1、使不同应用开发环境相互独立
2、环境升级不影响其他应用,也不会影响全局的python环境
3、防止出现包管理混乱及包版本冲突
3.补充
python 是解释型语言--->边解释边执行---->无论开发,运行python项目---->都需要有个解释器
开发项目,想给别人用--->别人不想装解释器--->把python代码使用pipinstaller--->打包成exe可执行文件---->本质是把解释器+代码打包到一个exe中了--->非常大的
Virtualenv安装+配置
windows
安装+配置虚拟环境管理器工作目录
1.安装两个模块
pip3.8 install virtualenv # 第三方虚拟环境
pip3.8 install virtualenvwrapper-win # 增加模块,使虚拟环境在win上更好用
2.配置环境变量:
变量名:WORKON_HOME 变量值:自定义存放虚拟环境的绝对路径
WORKON_HOME: D:\Virtualenvs
"""
控制面板 => 系统和安全 => 系统 => 高级系统设置 => 环境变量 => 系统变量 => 点击新建 => 填入变量名与值
"""
3.同步配置信息
去Python3的安装目录 => Scripts文件夹 => virtualenvwrapper.bat => 双击
MacOS、Linux
安装+工作文件+配置
1.安装模块
pip3 install virtualenv
pip3 install virtualenvwrapper
2.复制virtualenvwrapper.sh到/usr/local/bin路径下
1.先找到virtualenvwrapper的工作文件 virtualenvwrapper.sh,该文件可以刷新自定义配置,但需要找到它
ps:找virtualenvwrapper的命令:sudo find / -name virtualenvwrapper.sh 2>/dev/null
"""
1.MacOS可能存在的位置 /Library/Frameworks/Python.framework/Versions/版本号文件夹/bin
2.Linux可能所在的位置 /usr/local/bin | ~/.local/bin | /usr/bin
"""
2.建议不管virtualenvwrapper.sh在哪个目录,保证在 /usr/local/bin 目录下有一份
3.如果不在 /usr/local/bin 目录,如在 ~/.local/bin 目录,则复制一份到 /usr/local/bin 目录
sudo cp -rf /路径/virtualenvwrapper.sh /usr/local/bin
"""
要验证文件是否成功复制到 /usr/local/bin 目录中:
ls -lF /usr/local/bin/virtualenvwrapper.sh
"""
4.配置环境变量
1.在 ~/.bash_profile 完成配置,virtualenvwrapper的默认存放虚拟环境路径是 ~/.virtualenvs
WORKON_HOME=自定义存放虚拟环境的绝对路径,需要自定义就解注
VIRTUALENVWRAPPER_PYTHON=/usr/local/bin/python3 # 指定的是那个解释器
source /usr/local/bin/virtualenvwrapper.sh # 指定的是virtualenvwrapper.sh
"""
查看指定的解释器版本:which python3.10
na@Nas-MacBook-Pro:which python3.10
/Library/Frameworks/Python.framework/Versions/3.10/bin/python3.10
"""
5.在终端让配置生效:
source ~/.bash_profile
"""
nano ~/.bash_profile
export VIRTUALENVWRAPPER_PYTHON=/Library/Frameworks/Python.framework/Versions/3.10/bin/python3.10
source /usr/local/bin/virtualenvwrapper.sh
按下 Ctrl + X 组合键,然后按 Y 键保存修改。
source ~/.bash_profile
"""
Virtualenv使用
ps:重新打开命令窗口,可以执行下面的命令(mac不用关)
1.创建虚拟环境到配置的WORKON_HOME路径下,一旦进入到虚拟环境,所有安装模块操作,都是操作虚拟环境
1.选取默认Python环境创建虚拟环境:
mkvirtualenv 虚拟环境名称 # 默认以python 这个解释器来创建虚拟环境
2.基于某Python环境创建虚拟环境:创建虚拟环境并进入虚拟环境
mkvirtualenv -p python2.7 虚拟环境名称
mkvirtualenv -p python3.6 虚拟环境名称
2、查看已有的虚拟环境:workon
3、使用某个虚拟环境:workon 虚拟环境名称
4、进入|退出 该虚拟环境的Python环境:python | exit()
5、为虚拟环境安装模块:pip或pip3 install 模块名
6、退出当前虚拟环境:deactivate
7.删除虚拟环境(删除当前虚拟环境要先退出)
-- rmvirtualenv 虚拟环境名称
环境变量
1.我们在命令行中,执行一个命令,写命令名字执行
1.当前路径下有这个可执行文件
2.这个可执行文件,在环境变量中
2.加环境变量的目的
在任意路径下敲 可执行文件都可以,原因是当前敲的可执行文件路径在环境变量中
3.环境变量有两层
用户环境变量:只有当前用户生效
系统环境变量:所有用户都生效
4.mac平台,需要用命令行操作,文件
用户环境变量:.bash_profile(当前命令窗口)
zsh(之后都生效)
文档mac:https://www.jianshu.com/p/8e51bc9cebfa
pycharm创建虚拟环境
打开的项目没有使用虚拟环境,在pycharm中如何配置
调整目录结构
调整目录结构
├── luffyapi
├── logs/ # 项目运行时/开发时日志目录 - 包
├── manage.py # 脚本文件
├── luffyapi/ # 项目主应用,开发时的代码保存 - 包
├── apps/ # 开发者的代码保存目录,以模块[子应用]为目录保存 - 包
├── libs/ # 第三方类库的保存目录[第三方组件、模块] - 包
├── settings/ # 配置目录 - 包
├── dev.py # 项目开发时的本地配置
└── prod.py # 项目上线时的运行配置
├── urls.py # 总路由
└── utils/ # 多个模块[子应用]的公共函数类库[自己开发的组件]
└── scripts/ # 保存开发项目的脚本文件 - 文件夹
创建项目
ps:调整完目录结构后:修改manage.py的文件: os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffy_api.settings.dev'),之后项目可以起起来了
1.调整目录后,以后app全都放在apps文件夹下
1.创建app,进入到apps的路径
python ../../manage.py startapp user # 在apps目录下创建出一个userapp
"""
cd luffy_api/apps
python ../../manage.py startapp user
"""
2.注册到配置文件中
方式一:
全路径:'luffy_api.apps.user' # 要改app下apps.py中的name:luffy_api.apps.user
方式二:
把apps所在路径加入到环境变量后,直接写app名字即可:user
"""
BASE_DIR = Path(__file__).resolve().parent.parent
# print(BASE_DIR) # /Users/na/PycharmProjects/luffy_api/luffy_api
# 把apps所在路径,加入到环境变量,以后引入app直接写app名字即可
import os
apps = os.path.join(BASE_DIR,'apps')
sys.path.insert(0,apps)
"""
ps:sys.path.insert(0,str(BASE_DIR)) # 要str一下,以后导入模块,路径短一些
设置两套配置文件
1.所有项目,都会有多套配置文件
开发阶段配置:settings.dev
上线阶段配置:settings.prod.py
2.django项目运行,优先运行settings.py 配置文件
命令运行:python manage.py runserver--->所以,manage中的配置文件路径要正确
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffy_api.settings.dev')
一旦把dev.py 移动到settings文件夹下后,配置文件中BASE_DIR路径变了,apps拼接的路径也变了,要相应的修改
3.把小luffy_api和apps加入环境变量
sys.path.insert(0, str(BASE_DIR)) # 要str一下,以后导入模块,路径短一些
apps = os.path.join(BASE_DIR, 'apps')
sys.path.insert(0, apps)
4.项目上线,不适用manage.py 运行--->使用uwsgi运行wsgi.py 文件---->修改这个文件的配置
-asgi.py-->
-wsgi.py -->os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffy_api.settings.prod')
配置文件指定 prod.py 以后上线使用这个配置文件
数据库配置
软件开发模式
1.学bbs,设计创建出所有表,直接迁移,后期没改过 -->瀑布开发模式
2.学路飞,先设计,开发一点,测试上线一点----->敏捷开发
创建数据库+表
ps:如果用户表想用 auth的user表扩写,在一开始就要定好
1.使用mysql数据库,创建一个库,navicate创建即可
2.新建一个userapp,基于auth的user表扩写用户表
class User(AbstractUser):
mobile = models.CharField(max_length=11, unique=True)
# 需要pillow包的支持
icon = models.ImageField(upload_to='icon', default='icon/default.png')
class Meta:
db_table = 'luffy_user' # 指定表名
verbose_name = '用户表' # 后台管理看到的中文
verbose_name_plural = verbose_name
def __str__(self): # 打印对象,显示的
return self.username
3.迁移数据(mysql-->配置文件配置)
1.项目的数据库用户,不使用root用,新建一个mysql用户给项目用
因为root用户权限太大了,新建用户权限小一些
创建一个luffy用户,授权,只授予luffy库的权限
1.查看当前数据库有哪些用户:select user,host,password from mysql.user;
2.创建luffy用户
1.创建一个用户叫luffy,密码是:Luffy123?,可以本地链接,对luffy库所有表有权限:
grant all privileges on luffy.* to 'luffy'@'localhost' identified by 'Luffy123?';
"""
mysql8.xx版本:
CREATE USER 'luffy'@'localhost' IDENTIFIED BY 'Luffy123?';
GRANT ALL PRIVILEGES ON luffy.* TO 'luffy'@'localhost';
"""
2.创建一个用户叫luffy,密码是:Luffy123?,可以远程地链接,对luffy库所有表有权限
grant all privileges on luffy.* to 'luffy'@'%' identified by 'Luffy123?';
"""
mysql8.xx版本:
CREATE USER 'luffy'@'%' IDENTIFIED BY 'Luffy123?';
GRANT ALL PRIVILEGES ON luffy.* TO 'luffy'@'%';
FLUSH PRIVILEGES;
"""
ps:
本地连接:mysql -uluffy -pLuffy123?
远程连接:mysql -uluffy -h 192.168.0.152 -P 3306 -pLuffy123?
"""
mac查看ip地址:ifconfig | grep "inet "
"""
2.项目配置文件配置
1.django项目如果使用pymsql链接mysql,需要加两句话,加在哪不重要,重要的是它一定要执行
import pymysql
pymysql.install_as_MySQLdb()
django 2 高一点的版本就会报错,需要改源码,麻烦
2.咱们以后,使用mysqlclient 操作mysql pip install mysqlclient,不需要任何配置,就可以操作mysql
win:看人品,也有解决方案
mac:很难装,也有,比较麻烦
linux:有解决方案
3.执行迁移文件
两条命令