百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

是时候学习Web开发了,1小时用Python开发一个博客系统

ccwgpt 2024-10-22 10:22 29 浏览 0 评论

来源:麦叔编程

作者:麦2叔

开发一个包含数据库的简单网站系统是Web开发入门的最好方式。

Flask是Python最热门的两个Web框架之一,是最简单易用,容易上手的框架。

本系列使用Python的Flask框架开发一个简易的博客系统,共用时约90分钟。整个文章分为3部分,今天是第「2」部分。第3部分本周日发布。

?

原计划是分成2部分,篇幅有点长,临时改成了3部分。

?

第1部分的链接:

是时候学习Web开发了!1小时用Python开发博客系统【1】

整个文章包括以下内容,第1部分涵盖前5部分,今天包含中间的3部分:

  1. 安装flask
  2. 创建项目
  3. 运行你的第一个网站
  4. 创建一个像样的网页
  5. 用样式表美化网页
  6. 「使用模板和bootstrap」
  7. 「创建文章数据库」
  8. 「显示所有的文章」
  9. 显示一篇文章
  10. 发布新文章
  11. 修改文章内容
  12. 删除文章
  13. 关于麦叔页面

今天的文章信息量有点大,所有源代码都可以关注公众号「麦叔编程」,回复「fff」获得链接。

我们开始吧!上次我们已经创建好了flask程序和一个应用了基本样式的页面:

一、使用模板和Bootstrap

我们要继续「美化」页面。

大部分网站都有很多页面,这些页面都会共用同样的菜单栏。总不能开发没页面的时候都要把菜单栏写一遍吧?

这里就用到了「模板」的概念,我们创建一个模板,模板包含了菜单等共同的部分,而具体页面只要往模板中填空就行了。

我们的博客最终的样式是这样的,它包含了「列表」「新建」「详情」「修改」「关于麦叔」等多个页面。这些页面共用同一个模板。

1.下载JavaScript和CSS文件

我们需要用到jquery和bootstrap,先去我的git上下载这几个文件,下载方法:关注麦叔编程,回复210820。

下载完后分别放在static目录下的css和js目录下。其中js目录需要先创建出来。

2.在templates目录下创建一个新的文件:base.html

<!doctype html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
    <link rel="stylesheet" href="{{ url_for('static', filename= 'css/bootstrap.min.css') }}">
    <title>{% block title %} {% endblock %}</title>
  </head>
  <body>
    <nav class="navbar navbar-expand-md navbar-light bg-light">
        <a class="navbar-brand" href="{{ url_for('index')}}">麦叔的博客</a>
        <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNav" aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation">
            <span class="navbar-toggler-icon"></span>
        </button>
        <div class="collapse navbar-collapse" id="navbarNav">
            <ul class="navbar-nav">
            <li class="nav-item active">
                <a class="nav-link" href="#">关于麦叔</a>
            </li>
            </ul>
        </div>
    </nav>
    <div class="container">
        {% block content %} {% endblock %}
    </div>


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

   </body>
</html>

这里面信息量有点大,我来一个个解释:

  • 使用url_for方法引入了前面下载的1个css文件和3个js文件。之前我们创建的style.css文件就没用了,可以删除了。
  • 在开头部分的{% block title %} {% endblock %}是标题(title)占位符,相当于定义了名为title的变量,后面会被具体内容替换掉。
  • 在中间部分的{% block content %} {% endblock %}是网页内容的占位符,相当于定义了名为content的变量,后面会被具体内容替换掉。
  1. 修改index.html中的内容{% extends 'base.html' %}
    {% block content %}
    <h1>{% block title %} 欢迎来看麦叔的博客 {% endblock %}</h1>
    {% endblock %}
  2. 第一行extends 'base.html'表示我们要使用前面定义的base.html这个模板。要使用这个模板,就要把模板中的两个占位符(两个填空题)给填写好。
  3. 放在{% block content %}和{% endblock %}中间的所有内容都会填写在content这个占位符中。
  4. 放在{% block title %}和{% endblock %}中间的内容会填写在title占位符中。注意这里的title变量会被重用。它既是title占位符的内容,也是content占位符的一部分。
  5. 刷新页面,应该看到如下的效果。如果不是,仔细检查一下哪里是不是漏掉了,或者拼写错误了。这里虽然没有很大的变化,但是我们已经搭建好了模板,以后开发的页面内容都可以重用这个模板,而页面本身会变得很简单。

二、创建文章数据库

博客系统会有很多文章,我们要把这些文章保存到数据库。

数据库有很多选择,比如MySQL, postgresql,Oracle, sqlite3等。

我们今天要使用最轻量级的数据库sqlite3,Python自带了这个库,所以不需要额外安装。

  1. 在blog.py同目录下创建一个文件db.sql,里面是创建数据库表的SQL语句:DROP TABLE IF EXISTS posts;
    CREATE TABLE posts (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    created TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
    title TEXT NOT NULL,
    content TEXT NOT NULL
    );
  2. 首先看看posts表是否存在,如果存在,先删除它。
  3. 创建一个名为posts的表,其中包含id,title,content以及创建时间(created)等字段。
  4. 在blog.py同目录下创建文件init_db.py这是一个python代码文件,它连接到sqlite数据库,执行上面的db.sql中的语句,然后再插入两条文章。具体细节见注释:import sqlite3
    # 创建数据库链接
    connection = sqlite3.connect('database.db')
    # 执行db.sql中的SQL语句
    with open('db.sql') as f:
    connection.executescript(f.read())
    # 创建一个执行句柄,用来执行后面的语句
    cur = connection.cursor()
    # 插入两条文章
    cur.execute("INSERT INTO posts (title, content) VALUES (?, ?)",
    ('学习Flask1', '跟麦叔学习flask第一部分')
    )
    cur.execute("INSERT INTO posts (title, content) VALUES (?, ?)",
    ('学习Flask2', '跟麦叔学习flask第二部分')
    )
    # 提交前面的数据操作
    connection.commit()
    # 关闭链接
    connection.close()
  5. 打开一个命令行,运行init_db.py如果没有报错,就会发现文件夹下多了database.db,这就是数据库文件。

三、展示文章列表

现在数据库里有两篇文章,我们可以使用python从数据库中获取数据,并且展现到网页上。

  1. 修改blog.py,具体细节见注释import sqlite3 #引入sqlite3
    from flask import Flask, render_template
    app = Flask(__name__)
    # 创建一个函数用来获取数据库链接
    def get_db_connection():
    # 创建数据库链接到database.db文件
    conn = sqlite3.connect('database.db')
    # 设置数据的解析方法,有了这个设置,就可以像字典一样访问每一列数据
    conn.row_factory = sqlite3.Row
    return conn
    @app.route('/')
    def index():
    # 调用上面的函数,获取链接
    conn = get_db_connection()
    # 查询所有数据,放到变量posts中
    posts = conn.execute('SELECT * FROM posts').fetchall()
    conn.close()
    #把查询出来的posts传给网页
    return render_template('index.html', posts=posts)
    @app.route('/about')
    def about():
    return render_template('about.html')
  2. 修改index.html之前只显示了一个标题,现在要循环blog.py中传过来的posts列表,把每一篇文章显示出来。注意for循环在页面中的写法,和python代码很类似,只不过要用{%和%}包起来。{% extends 'base.html' %}
    {% block content %}
    <h1>{% block title %} 欢迎来看麦叔的博客 {% endblock %}</h1>
    {% for post in posts %}
    <a href="#">
    <h2>{{ post['title'] }}</h2>
    </a>
    <span class="badge badge-primary">{{ post['created'] }}</span>
    <hr>
    {% endfor %}
    {% endblock %}
  3. 刷新页面,应该可以看到这样的效果:如果不行,仔细对比一下,看看少了什么或者有没有拼写错误。

今天就到这里了,后面的部分会在本周日发布,到时候也会发视频到bilibili,请保持关注。

整个文章包括以下内容,第1部分涵盖前5部分,今天包含后面的部分:

  1. 安装flask
  2. 创建项目
  3. 运行你的第一个网站
  4. 创建一个像样的网页
  5. 用样式表美化网页
  6. 使用模板和bootstrap
  7. 创建文章数据库
  8. 显示所有的文章
  9. 「显示一篇文章」
  10. 「发布新文章」
  11. 「修改文章内容」
  12. 「删除文章」
  13. 关于麦叔页面

相关推荐

腾讯开源框架TarsCpp-rpc设计分析-server(二)

2Tars协议2.1是什么借用官方说法:TARS编码协议是一种数据编解码规则,它将整形、枚举值、字符串、序列、字典、自定义结构体等数据类型按照一定的规则编码到二进制数据流中。对端接收到二进制数据流...

微服务调用为什么用RPC框架,http不更简单吗?

简单点,HTTP是协议,RPC是概念!实现RPC可以基于HTTP协议(Feign),TCP协议(Netty),RMI协议(Soap),WebService(XML—RPC)框架。传输过程中,也因为序列...

go-zero:开箱即用的微服务框架(gin框架微服务)

go-zero是一个集成了各种工程实践的Web和rpc框架,它的弹性设计保障了大并发服务端的稳定性,并且已经经过了充分的实战检验。go-zero在设计时遵循了“工具大于约定和文档”的理...

SOFARPC :高性能、高扩展性、生产级的 Java RPC 框架

#暑期创作大赛#SOFARPC是一个高性能、高扩展性、生产级的JavaRPC框架。在蚂蚁金服,SOFARPC已经使用了十多年,已经发展了五代。SOFARPC致力于简化应用程序之间的RPC...

自研分布式高性能RPC框架及服务注册中心ApiRegistry实践笔记

痛点1.bsf底层依赖springcloud,影响bsf更新springboot新版本和整体最新技术版本升级。2.eureka已经闭源,且框架设计较重,同时引入eureka会自行引入较多sprin...

Rust语言从入门到精通系列 - Tonic RPC框架入门实战

Rust语言是一种系统级语言,被誉为“没有丧失性能的安全语言”。Rust语言的优势在于其内存安全机制,在编译时就能保证程序的内存安全。Tonic模块是Rust语言的一个RPC(RemoteProce...

腾讯开源框架TarsCpp-rpc设计分析-client(一)

前言Tars是腾讯开源的微服务平台,包含了一个高性能的rpc框架和服务治理平台,TarsCpp是其C++版本。对于以C++为主要开发语言,同时还想深入了解rpc和微服务框架具体实现的同学来说,Tars...

设计了一款TPS百万级别的分布式、高性能、可扩展的RPC框架

为啥要开发RPC框架事情是这样的,在开发这个RPC框架之前,我花费了不少时间算是对Dubbo框架彻底研究透彻了。冰河在撸透了Dubbo2.x和Dubbo3.x的源码之后,本来想给大家写一个Dubbo源...

rpc框架使用教程,超级稳定好用,大厂都在使用

rpc是什么远程调用协议如何使用导入依赖<dependency><groupId>org.apache.dubbo</groupId><art...

Layui 框架实战:动态加载 Select 与二级联动全解析

在现代Web开发中,下拉选择框(Select)是用户输入数据时不可或缺的组件。很多时候,我们需要的选项并非静态写死在HTML中,而是需要根据业务逻辑从后端动态获取。更有甚者,我们可能需要实现“...

15个能为你节省数百小时的前端设计神器,从UI库到文档生成

无论你是刚开始开发之旅的新手,还是疲于应付生产期限的资深程序员,有一个真理始终不变:正确的工具能彻底改变你的工作流程。多年来,我测试了数百个开发工具——有些实用,大多数平庸。但有一批免费网站经受住了时...

Layui与WinForm通用权限管理系统全解析

嘿,小伙伴们,今天咱们来聊聊Layui和WinForm这两个框架在通用权限管理系统中的应用。别担心,我会尽量用简单易懂的语言来讲解,保证让大家都能跟上节奏!首先说说Layui。Layui是一个前端UI...

纯Python构建精美UI!MonsterUI让前端开发效率飙升

“无需CSS知识,告别类名记忆,11行代码实现专业级卡片组件”在传统Web开发中,构建美观界面需要同时掌握HTML、CSS、JavaScript三剑客,开发者不得不在多种语言间频繁切换。即使使用Boo...

WebTUI:将终端用户界面(TUI)之美带到浏览器的CSS库

在当今Web技术飞速发展的时代,界面设计愈发复杂多样。然而,随着现代化工具的广泛使用,一些开发者开始回归极简风格,追求一种简洁而富有韵味的设计。WebTUI正是这样一款CSS库,它将经典的终...

人教版二年级下册生字描红汇总(拼音+笔顺+描红),可打印!

可定制内容,评论区留言。本次整理的为人教版二年级下册所有生字,共计300个;写字是小学阶段一项重要的基本功训练,把汉字写得正确、工整、美观,可以提高运用汉字这一交际工具的准确性和效率。对小学生进行写字...

取消回复欢迎 发表评论: