美文网首页
Python学习笔记-第16天:实战练习(3)

Python学习笔记-第16天:实战练习(3)

作者: 6d1bf2ffc4f3 | 来源:发表于2019-12-25 18:34 被阅读0次

    第十六天 实战练习(3)

    今天计划用Python继续一个web开发的实战项目练习,学习项目及练习源码地址:
    GitHub源码

    配置文件

    项目中很多信息在运行时是可变的,特别是在开发阶段,测试阶段,以及正式部署阶段都需要不同的配置信息。如数据库配置等。

    实战目的,通过系统环境变量自动生成不动的配置文件。

    在项目根目录新建文件config.py

    class Conf:
        def __init__(self):
    
            self.app = type("app", (object,), {
                "host": os.getenv("APP_HOST", "0.0.0.0"),
                "port": os.getenv("APP_PORT", "8000"),
                "static":os.path.join(os.path.dirname(os.path.abspath(__file__)),'www', 'static'),
                "routedir": os.path.join(os.path.dirname(os.path.abspath(__file__)), 'web','routers')
            })
            self.redis = type("redis", (object,), {
                "host": os.getenv("REDIS_HOST", "127.0.0.1"),
                "port": int(os.getenv("REDIS_PORT", "6379")),
                "password": os.getenv("REDIS_PASSWORD", "123456"),
            })
            self.mysql = type("mysql", (object,), {
                "host": os.getenv("MYSQL_HOST", "127.0.0.1"),
                "port": int(os.getenv("MYSQL_PORT", "3306")),
                "password": os.getenv("MYSQL_PASSWORD", "root"),
                "user": os.getenv("MYSQL_USER", "root"),
                "database": os.getenv("MYSQL_DATABASE", "awesome"),
                "charset": os.getenv("MYSQL_CHARSET", "utf8"),
                "autocommit": os.getenv("MYSQL_AUTOCOMMIT", "True"),
                "maxsize": os.getenv("MYSQL_MAXSIZE", "10"),
                "minsize":os.getenv("MYSQL_MINSIZE", "1"),
            })
    
    config = Conf()
    

    使用:

    pool = await aiomysql.create_pool(
                        host = config.mysql.host,
                        port = config.mysql.port,
                        user = config.mysql.user,
                        password = config.mysql.password,
                        db = config.mysql.database,
                        charset = config.mysql.charset,
                        autocommit = config.mysql.autocommit == 'True',
                        maxsize = int(config.mysql.maxsize),
                        minsize = int(config.mysql.minsize),
                        loop = loop)
    

    MVC

    模型Model层

    在之前的学习中已经搭建了Model层,通过orm自动映射数据库字段

    控制器Controller

    控制器层我个人习惯拆分成两层:路由层(routes)和服务层(services)

    • 路由层

      负责处理响应用户请求:包括请求数据的验证等并根据业务层的处理结果返回数据(模板)

    • 服务层

      处理实际的业务逻辑,并将结果返回给路由层

    模板

    aiohttp.web并不直接提供模板读取,不过可以使用第三方库 aiohttp_jinja2,该库是由aiohttp作者维护的。
    使用起来也很简单。首先我们用aiohttp_jinja2.setup()来设置下jinja2环境。

    pip3 install aiohttp_jinja2

    使用方法:

    aiohttp_jinja2.setup(app, loader=jinja2.FileSystemLoader(TEMPLATE_DIR))

    在controller中使用:

    @aiohttp_jinja2.template('index.html')
    async def index(request):
        return
    

    Jinja2模板用法

    1. 语法

      控制结构 {% %}

      变量取值 {{ }}

      注释 {# #}

      jinja2模板中使用 {{ }} 语法表示一个变量,它是一种特殊的占位符。当利用jinja2进行渲染的时候,它会把这些特殊的占位符进行填充/替换,jinja2支持python中所有的Python数据类型比如列表、字段、对象等。

    2. 过滤器

      变量可以通过“过滤器”进行修改,过滤器可以理解为是jinja2里面的内置函数和字符串处理函数。

      内置过滤器有:

      safe: 渲染时值不转义
      capitialize: 把值的首字母转换成大写,其他子母转换为小写
      lower: 把值转换成小写形式
      upper: 把值转换成大写形式
      title: 把值中每个单词的首字母都转换成大写
      trim: 把值的首尾空格去掉
      striptags: 渲染之前把值中所有的HTML标签都删掉
      join: 拼接多个值为字符串
      replace: 替换字符串的值
      round: 默认对数字进行四舍五入,也可以用参数进行控制
      int: 把值转换成整型
      

      使用方法:

      {{ 'abc' | captialize }}

    3. 循环控制

      在模板中只能使用for循环控制,没有while。语法和Python一致

      <ul>
      {% for user in users %}
      <li>{{ user.username | title }}</li>
      {% endfor %}
      </ul>
      
    4. 继承和super函数

      jinja2中最强大的部分就是模板继承。模板继承允许我们创建一个模板文件,其他文件从该文件继承,然后针对自己需要的地方进行修改。

      jinja2的模板文件中,利用block关键字表示其包涵的内容可以进行修改。

    相关文章

      网友评论

          本文标题:Python学习笔记-第16天:实战练习(3)

          本文链接:https://www.haomeiwen.com/subject/eixhoctx.html