linux下创建虚拟环境

  • 安装python3的虚拟环境包
1
sudo  apt-get install python3-venv
  • 创建虚拟环境
1
python3 -m venv v1
  • 使用虚拟环境 激活虚拟环境
1
source v1/bin/activate

Pymysql是python链接mysql数据进行操作的工具 api

SQLAlchemy是Python编程语言下的一款开源软件。提供了SQL工具包及对象关系映射(ORM)工具

Flask-SQLAlchemy是在flask框架中使用SQLAlchemy的一个工具包,产品,依赖SQLAlchemy

flask的使用

1
2
3
4
5
6
7
8
9
from flask import Flask
app = Flask(__name__)

@app.route('/')
def hello_world():
return 'Hello World!'

if __name__ == '__main__':
app.run()

首先,我们导入了Flask类。这个类的实例将会是我们的WSGI应用程序。

接下来,我们创建一个该类的实例,第一个参数是应用模块或者包的名称。 如果你使用单一的模块(如本例),你应该使用__name__,因为模块的名称将会因其作为单独应用启动还是作为模块导入而有不同( 也即是’main’或实际的导入名)。这是必须的,这样 Flask 才知道到哪去找模板、静态文件等等。详情见Flask的文档。

然后,我们使用route()装饰器告诉Flask什么样的URL能触发我们的函数。这个函数的名字也在生成URL时被特定的函数采用这个函数返回我们想要显示在用户浏览器中的信息。

最后我们用run()函数来让应用运行在本地服务器上。 其中if__name__‘main’:确保服务器只会在该脚本被 Python 解释器直接执行的时候才会运行,而不是作为模块导入的时候。

  • 在app.py文件中添加以下内容
1
2
3
4
5
6
7
8
9
10
@app.route('/abc')
def demo():
return 'aabbcc'

@app.route('/love')
def love():
return '<h1 style="color:red;">iloveyou</h1>'

if __name__ == '__main__':
app.run(debug=True,host='0.0.0.0',port="8080")

如果你运行了这个服务器,你会发现它只能从你自己的计算机上访问,网络中其它任何的地方都不能访问。在调试模式下,用户可以在你的计算机上执行任意Python代码。因此,这个行为是默认的。如果你禁用了debug或信任你所在网络的用户,你可以简单修改调用run()的方法使你的服务器公开可用,如下:

1
app.run(host='0.0.0.0')

这会让操作系统监听所有公网IP。

注意:使用pycharm建立flask项目时,不在程序中这样写,要改变启动的配置

虽然run()方法适用于启动本地的开发服务器,但是你每次修改代码后都要手动重启它。这样并不够优雅,而且Flask可以做到更好。如果你启用了调试支持,服务器会在代码修改后自动重新载入,并在发生错误时提供一个相当有用的调试器。

有两种途径来启用调试模式。一种是直接在应用对象上设置:

1
2
app.debug=True
app.run()

另一种是作为 run 方法的一个参数传入:

1
app.run(debug=True)
  • 给URL添加变量部分,在app.py文件中添加以下内容
1
2
3
4
5
6
7
@app.route('/user/<username>')
def user_books(username='aa'):
return username

@app.route('/user/<username>/p/<int:bookid>')
def user_p_book(username,bookid):
return '您正在访问'+username+'的博客中的id为'+str(bookid)+'博文'

把这些特殊的字段标记为<variable_name>,这个部分将会作为命名参数传递到你的函数。规则可以用converter:variable_name指定一个可选的转换器

转换器有下面几种:

converter 含义
int 接受整数
float 同int,但是接受浮点数
path 和默认的相似,但也接受斜线
  • URL结尾带斜线与不带斜线的区别,在app.py文件中添加以下内容
1
2
3
@app.route('/user/<username>/p/<int:bookid>/')
def user_p_book(username,bookid):
return '您正在访问'+username+'的博客中的id为'+str(bookid)+'博文'

第一种情况的URL结尾带斜线,访问一个结尾不带斜线的URL会被Flask重定向到带斜线的规范URL去。第二种情况的URL结尾不带斜线,访问结尾带斜线的URL会产生一个 404 “Not Found” 错误。

注意:最好使用url结尾不带斜线的,这样保证了URL的唯一,有助于避免搜索引擎索引同一个页面两次

  • 构造url(反向解析url),在app.py文件中添加以下内容
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
from flask import Flask,url_for
# 测试 构造url 反向解析
@app.route('/reverse',methods=['GET','POST','PUT'])
def url_reverse():
r1 = url_for('hello_world')
r2 = url_for('demo')
r3 = url_for('love',abc='123')
r4 = url_for('user_books',username='zhangsan',bookid=12)
r5 = url_for('user_p_book',username='zhangsan',bookid=12)
print(r1)
print(r2)
print(r3)
print(r4)
print(r5)
return '构造url 反向解析'

默认情况下,路由只回应GET请求,但是通过route()装饰器传递methods参数可以改变这个行为。一个参数代表只一个请求方式.

1
2
3
4
5
/
/abc
/love?abc=123
/user/zhangsan?bookid=12
/user/zhangsan/p/12/

如果url的无变量部分,解析时传入的参数变成url后的键值对

  • templates模板的使用
1
2
3
4
5
6
@app.route('/')
def hello_world():
# return 'Hello World!'
uname = 'lisi'
# 加载模板
return render_template('public/index.html',username=uname)