首頁 >後端開發 >Python教學 >python實作Todo清單的程式碼範例

python實作Todo清單的程式碼範例

不言
不言轉載
2018-11-15 14:56:182719瀏覽

這篇文章帶給大家的內容是關於python實作Todo清單的程式碼範例,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

新增分頁功能

第一步:是對視圖函數的改寫,透過查詢資料庫數據,進行分頁顯示

# 修改清单显示的视图函数
@app.route('/list/')
@app.route('/list/<page>')
def todo_list(page=1):
    todos = Todo.query.paginate(page,5)
    parts = Department.query.all()
    return  render_template('todo_list.html',todos=todos,parts=parts)</page>

第二步:改寫html文件,實現分頁顯示,重新定義一個巨集文件

{# marco_page.html#}
{% macro paginate(fname, todos) %}
    {#    dataObj 就是views函数中传递过来的Paginate实例化的对象;#}
    
            {#        判断是否由上一页, #}         {% if todos.has_prev %}             {#        /list/4/   ===> /list/3/#}             
  • 前一页
  •         {% else %}             
  • 前一页
  •         {% endif %}         {#   根据从数据库中查询的数据, 来确定分页的个数, 使用for循环   #}         {#  返回一个迭代器, 如果有100页, 薄嗯不会返回100个数字, 而是1 2 。。。。 99 100        #}         {% for page in todos.iter_pages(right_current=2) %}             {# page: 要生成html代码的页数,  todos.page: 用户希望显示数据的页数            #}             {% if page == todos.page %}                 
  • {{ page }}                 
  •             {% elif page == None %}                 
  • ...
  •             {% else %}                 
  • {{ page }}
  •             {% endif %}         {% endfor %}                  {#        判断是否有后一页 #}         {% if todos.has_next %}             {#        /list/4/   ===> /list/3/#}             
  • 后一页
  •         {% else %}             
  • 后一页
  •         {% endif %}     

{% endmacro %}

第三步,清單顯示的範本文件呼叫分頁顯示列

        {% from 'macro_page.html' import paginate %}

        {{ paginate('todo_list', todos) }}

python實作Todo清單的程式碼範例

新增日誌收集功能

第一步,為原有資料庫操作文件新增新的資料庫表格Userlog,用來存放任務的修改編輯日誌
對原有的資料庫進行再新增時,需要進行資料庫遷移。

class Userlog(db.Model):
    id = db.Column(db.Integer, autoincrement=True, primary_key=True)
    add_time = db.Column(db.DateTime, default=datetime.now())  # 创建时间
    ip = db.Column(db.String(200), nullable=False) # 登录ip
    content = db.Column(db.String(200))
    area =  db.Column(db.String(200))  # 用户登录地点
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'))  # 外键

    def __repr__(self):
        return '<userlog:>' % (self.ip)</userlog:>

確保你有一個關於資料庫遷移的文件,基礎代碼如下

# manage.py
from flask_migrate import MigrateCommand, Migrate
from flask_script import Shell,Manager
from todo_models import app,db,User,Department,Todo

manager = Manager(app)
migrate = Migrate(app,db)

manager.add_command('db',MigrateCommand)
if __name__ == '__main__':
    manager.run()

在terminal終端執行命令

python manage.py db init
python manage.py db migrate -m '添加日志信息'
python manage.py db upgrade

第二步,給路由和對應視圖函數加上採集的日誌資訊,以新增清單任務為例
修改狀態和刪除任務也加上日誌訊息,這裡省略

    userlog = Userlog(ip=request.remote_addr, area="西安",
                      user_id=1, content="添加任务%s" %(name))
    db.session.add(userlog)
    db.session.commit()

python實作Todo清單的程式碼範例

#

以上是python實作Todo清單的程式碼範例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除