Flask的快速入门详细笔记

时间:2023-03-08 17:55:21
Flask的快速入门详细笔记

Flask的框架结构对应关系及理解

1.简介

  简单介绍下Flask是一个轻量级的web前端框架,不像django那样本身具备一套完整的页面体系,轻量级说明了完全可以自定义,从功能逻辑到业务处理,都可以自定义设计,一个词概括:灵活。就如同现实买房子装修一样,就看个人是选择装修公司全包的那种(跟你看样板图,照着来一套),还是半包自己去DIY买材料到装修的选样等等。

2.入门

  首先入门来看下怎么写一段简单的flask代码入下图(pip 安装 flask这部分直接跳过了):

Flask的快速入门详细笔记

  上面段代码就是一个简单flask代码,首先导入import Flask类用app实例化后在用@app.route装饰器(会经常用到重点学)路由方法去加载页面中的方法及返回值

总结:

### 设置debug模式:

  1.在app.run()中传入一个关键字参数debug,app.run(debug=True),这就开启了debug调试模式

  2.debug模式的两大功能:

    一、当程序出现问题的时候,可以在页面中看到错误信息和出错的位置

    二、只要修改了项目中的Python文件,程序就会自动加载,不需要手动重启服务。

### 使用配置文件:

  1.新建一个config.py文件

  2.在主app文件中导入配置文件config.py,并配置到app中,示例代码如下:

    """

    import config

    app.config.from_object(config)

    """

  3.还有许多的其他参数,后期都是放到config.py文件中,比如`SECRET_KEY`,`SQLALCHEMY`.

### url传参数:

  1.参数的作用:可以在相同的URL,输入不同的参数,来返回不同的数据

  2.在flask中如何使用参数:

    """

    @app.route('/<str>')

    def input_num(str):

      return u'你输入的参数是: %s'%str

    """

    * 参数需要放在两个尖括号中(也是在网页地址url要输入的字符)

    * 视图函数中需要放和url中的参数同名的参数

### 反转URL:

  1.说明叫反转URL:从视图函数到url的转换叫反转url

  2.翻转url的用处:

    * 在页面重定向的时候,会使用url反转。例如:评论完成后返回当前页面

    * 在模板中,也会使用url反转。例如登陆页面时

### 页面跳转和重定向:

  1.用处:在用户访问登陆的页面的时候,如果用户没有登陆,就重定向到登陆页面

  2.代码如下:

  """

  from flask import redirect,url_for

  redirect(url_for('login'))

  @app.route('/login')

  def login():

    pass

  """

### Flask渲染Jinja2模板和传参:

  1.如何渲染模板:

    * 模板放在templates文件夹下

    * 从flask中导入render_template函数

    * 在视图函数中,使用return render_template('index.html')来返回相应页面

  2.模板传参

    * 如果只有一个或者少量参数,直接render_template函数中添加关键字参数即可

    * 如果有多个参数时,那么可以先把所有参数放入字典中,然后在render_template中使用两个**kwargs(可自定义名称),方便把字典转成关键参数传递进去,这样的代码更方便管理和使用。示例如下:

  3.在模板(index.html)中,如果要使用一个变量,语法是{{ variable }}

  4.访问模型中的属性或是字典,可以通过{{ params.property }}的形式,或则是{{ params['property'] }}

### if判断

  1.语法:

  """

  {% if 条件 %}

  {% else %}

  {% endif %}

  """

  2.if的使用,可以和Python中相差无几。

### for循环遍历列表和字典:

  1.字典的遍历,语法和python一样,可以使用items()、keys()、values()、iteritems()等等。

  """

  {% for k,v in dict.items() %}

    <p>{{ k }}:{{ v }}</p>

  {% endfor %}

  """

  2.列表的遍历,语法和python一样,示例如下:

  """

  {% for i in list %}

    <p>{{ i }}</p>

  {% endfor %}

  """

### 过滤器:

  1.介绍和语法:

    * 介绍:过滤器可以把原始的变量经过处理后再展示出来。

  2.default过滤器:如果当前变量不存在,就指定默认值展示。

    * 语法

    """

    {{ images | default() }}

    ""

  3.length过滤器:求列表或者字符串或者字典或者元组长度。

    """

    {{ list/dict/tuple | length }}

    """

Flask的快速入门详细笔记

end.abs过滤器:返回一个数值的绝对值。示例:-1|abs

### 继承与block

  1.继承作用与语法

    * 作用:可以把一些公共的代码放到父模板中,避免每个模板写相同的代码

    * 语法是: {% extend 'base.html' %}

  2.block实现:

    * 作用:可以让子模板实现一些自己的需求。父模板需要提前定义好。

    *注意点:子模板中的代码必须放入block块中。

### url链接:使用url_for(视图函数名称)可以反转成url

### 加载静态文件

  1.语法url_for('static',filename='路径')

  2.静态文件,flask会从static文件夹中开始寻找,所以不需要再写static文件路径

  3.可以加载css文件,可以加载js文件,还有image文件。

  """

  1.加载CSS文件写法:

  <link rel="stylesheet" href="{{ url_for('static',filename='css/bootstrap.css') }}">

  2.加载js文件写法:

  <script src="{{ url_for('static',filename='js/jquery.js') }}"></script>

  3.加载图片文件写法:

  <img src="{{ url_for('static',filename='image/pic.jpg') }}" alt="">

  """

### Mysql-python中间件的介绍与安装

  1.如果是在类unix系统上,直接进入虚拟环境输入sudo pip install mysql-python

  2.如果是在windows系统上,那么需要下载Mysql_python-1.2.5-cp27-none-win_amd64.whl在当前目录中执行

  pip install Mysql_python-1.2.5-cp27-none-win_amd64.whl安装即可

### Flask-SQLAlchemy的介绍与安装

  1.ORM: object Relationship Mapping(模型关系映射)

  2.flask-sqlalchemy是一套ORM框架。

  3.ORM的好处:可以让我们操作数据库跟操作对象是一样的,非常方便。因为一个表就抽象成一个类,一条数据

  就抽象成该类的一个对象。

  4.安装flask-sqlalchemy: sudo pip install sqlalchemy

### Flask-SQLAlchemy的使用

  1.初始化和设置数据库配置信息:

    * 使用flask_sqlalchemy中的SQLALchemy进行初始化:

    """

    from flask_sqlalchemy import SQLALchemy

    app = Flask(__name__)

    db = SQLALchemy(app)

    """

  2.设置配置信息在config文件中添加如下配置信息:

    """

  # dialect+driver://username:password@host:port/database
  DIALECT = 'mysql'
  DRIVER = 'mysqldb'
  USERNAME = 'root'
  PASSWORD = 'root'
  HOST = '127.0.0.1'
  PORT = '3306'
  DATABASE = 'lianxi'
  SQLALCHEMY_DATABASE_URI = "{}+{}://{}:{}@{}:{}/{}?charset=utf8".format(
DIALECT,DRIVER,USERNAME,PASSWORD,HOST,PORT,DATABASE)
  SQLALCHEMY_TRACK_MODIFICATIONS = False
    """
### 使用Flask-SQLAlchemy创建模型与表的映射:
  1.模型需要继承自db.Model,然后需要映射到表中的属性,必须写成db.Column的数据类型。
  2.数据类型:
    * db.Integer代表的是整形。
    * db.String代码的是varchar,需要指定最长的长度。
    * db.Text代码的是text。
  3.其他参数:
    * primary_key 代表是将这个字段设置为主键
    * autoincrement 代表是将这个字段设置自增长的
    * nullable 代表的是这个字段是否为空,默认可以为空,可以将这个值设置为False就是not null
  4.最后需要调用db.create_all来将模型真正的创建到数据库中
### Flask-SQLAlchemy数据的增、删、改、查:
  1.增:
    """
    article1 = Article(title=‘aaa',content='bbb')
    db.session.add(article1)
    事物
    db.session.commit()
    """
  2.查:
    """
    ret = Article.query.filter(Article.title=='aaa').first() 这里返回一个列表,first取第一个值没有
    就返回None,也可以用切片[0]的方式但是没有值会报异常,还有all()取所有值
    print ret.title,  ret.content来输出值
    """
  3.改:
    """
    先把你要更改的数据查找出来
    article1 = Article.query.filter(Article.title=='aaa').first()
    把这条数据,你需要修改的地方进行修改
    article1.title = 'new title'
    把事物的提交
    db.session.commit()
    """
  4.删:
    """
    把需要删除的数据查找出来
    article1 = Article.query.filter(Article.content='bbb').first()
    把这条数据删除掉
    db.session.delete(article1)
    做事物提交
    db.session.commit()
    """