Python3,网站搭建之编写API接口,让前端页面展示数据!

简介: Python3,网站搭建之编写API接口,让前端页面展示数据!

1. 安装第三方模块


1.1 flask_restplus 安装

cmd窗口,直接pip安装


pip install flask_restplus

1.2 werkzeug 安装

cmd窗口,直接pip安装


pip install werkzeug == 0.16.0

这里说一下,为啥安装旧版本,因为新版本(1.0.1),和flask不兼容,

会出现这个报告:


ImportError: cannot import name 'cached_property' from 'werkzeug'

2. 编写api接口


2.1创建api

这段代码在apis文件夹下的__init__.py编写


init.py


# -*- coding: utf-8 -*-
"""
@ auth : carl_DJ
@ time : 2020-9-09
"""
from flask_restplus import Api
from PaperWeb.Services import app
#创建api
api = Api(
    app,
    version='0.1.0',
    title='papers api ',
    description='论文分享网站',
    # authorizations={}  #认证
    ui = True
)
#导入papers 所有的内容,以便方便执行
from PaperWeb.Services.apis.papers import  *

2.2 创建papers

这个文件,主要是编写创建api的处理逻辑

papers.py


# -*- coding:utf-8 -*-
"""
@ auth : carl_DJ
@ time : 2020-9-09
"""
#编写api逻辑
from flask_restplus import Resource
from PaperWeb.Services.apis import api
from flask import request
from PaperWeb.Services.models.papers import PaperModel
class PapaerParsers(object):
    #定义一个静态方法
    #静态方法的作用:不需要实例化类,就可以直接调用对应的方法
    @staticmethod
    def getpaperlist():
        #解析器
        parser =api.parser()
        #往解析器里面添加参数,required = True 表示必传项
        parser = parser.add_argument('index',type = int,help ='第几页',required = True)
        parser = parser.add_argument('count',type = int,help ='一页包含的数据',required = True)
        return  parser
#创建获取接口的列表的类
class PaperList(Resource):
    #运用装饰器,将解析器运用到get方法
    @api.expect(PapaerParsers.getpaperlist())
    def get(self):
        index = int(request.values.get('index',0))
        count = int(request.values.get('count',0))
        papers,has_next = PaperModel.get_paper(index, count)
        #字典的形式,返回给前端
        return {
            'status':200,
            'msg':'success',
            'data': papers,
            'index':index,
            'count':count,  #一页有多少个数据
            'has_next':has_next  #是否有下一页
        }
#创建搜索的类,主要对作者进行搜索
class PaperSearch(Resource):
    #获取数据
    def get(self):
    # 这部分内容,与PaperList方法内容一样,只不过是查询的对象不同,不做展开
        pass
#定义一个命名空间
ns = api.namespace('papers',description = '论文接口')
#把ns 加载到PaperList中
ns.add_resource(PaperList,'','/')
#把ns 加载到PaperSearch中
ns.add_resource(PaperSearch,'/author','/author/')

2.3 获取papers列表的内容

我们在Services文件夹下,创建models文件夹,同时创建PaperModel 类

作用是为了,获取数据库的数据

papers.py


# -*- coding:utf-8 -*-
"""
@ auth : carl_DJ
@ time : 2020-9-09
"""
from PaperWeb.Services.libs.mysql import db
class PaperModel(object):
    #静态方法的作用:不需要实例化类,就可以直接调用对应的方法
    @staticmethod
    def get_paper(index,count):
        #获得papers列表的内容
        sql = f'''
            SELECT
                id,title,url
            FROM
                papers
            WHERE
                is_delect =0
            LIMIT{(index -1) * count},{count+1}
        '''
        result = db.query(sql)
        if not result:
            return [],0
        if len(result) ==count +1:
            result.pop()
            has_next = 1  # 是否有下一页
        else:
            has_next = 0
        return result,has_next

编写完上面的代码,我们就可以直接运行main.py文件了

然后就是完美的页面展示了~ ~

image.png

image.png


3. 总结


到现在,除了页面样式,功能部分,已经分享的差不多了。

关于页面样式,咱的js确实无法跟前端大佬相提并论,

只要功能没问题,我觉得,还算合格!!

如果还不太清楚网站创建流程,小鱼在重新上链接,按照顺序点击,学习就好了。

1.《Python3,网站搭建之数据库表设计及数据存储!》


2.《Python3,网站搭建之构建Flask项目,带你启动web服务! !》


3.《Python3,网站搭建之编写API接口,让前端页面展示数据!》


目录
相关文章
|
23天前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####
|
1月前
|
JavaScript 前端开发 程序员
前端原生Js批量修改页面元素属性的2个方法
原生 Js 的 getElementsByClassName 和 querySelectorAll 都能获取批量的页面元素,但是它们之间有些细微的差别,稍不注意,就很容易弄错!
|
22天前
|
数据采集 分布式计算 大数据
构建高效的数据管道:使用Python进行ETL任务
在数据驱动的世界中,高效地处理和移动数据是至关重要的。本文将引导你通过一个实际的Python ETL(提取、转换、加载)项目,从概念到实现。我们将探索如何设计一个灵活且可扩展的数据管道,确保数据的准确性和完整性。无论你是数据工程师、分析师还是任何对数据处理感兴趣的人,这篇文章都将成为你工具箱中的宝贵资源。
|
1月前
|
前端开发 JavaScript 搜索推荐
前端懒加载:提升页面性能的关键技术
前端懒加载是一种优化网页加载速度的技术,通过延迟加载非首屏内容,减少初始加载时间,提高用户访问体验和页面性能。
|
1月前
|
传感器 物联网 开发者
使用Python读取串行设备的温度数据
本文介绍了如何使用Python通过串行接口(如UART、RS-232或RS-485)读取温度传感器的数据。详细步骤包括硬件连接、安装`pyserial`库、配置串行端口、发送请求及解析响应等。适合嵌入式系统和物联网应用开发者参考。
53 3
|
1月前
|
数据采集 JavaScript 程序员
探索CSDN博客数据:使用Python爬虫技术
本文介绍了如何利用Python的requests和pyquery库爬取CSDN博客数据,包括环境准备、代码解析及注意事项,适合初学者学习。
82 0
|
1月前
|
数据采集 存储 分布式计算
超酷炫Python技术:交通数据的多维度分析
超酷炫Python技术:交通数据的多维度分析
|
2月前
|
存储 人工智能 前端开发
前端大模型应用笔记(三):Vue3+Antdv+transformers+本地模型实现浏览器端侧增强搜索
本文介绍了一个纯前端实现的增强列表搜索应用,通过使用Transformer模型,实现了更智能的搜索功能,如使用“番茄”可以搜索到“西红柿”。项目基于Vue3和Ant Design Vue,使用了Xenova的bge-base-zh-v1.5模型。文章详细介绍了从环境搭建、数据准备到具体实现的全过程,并展示了实际效果和待改进点。
190 2
|
2月前
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
56 0
|
2月前
|
人工智能 自然语言处理 运维
前端大模型应用笔记(一):两个指令反过来说大模型就理解不了啦?或许该让第三者插足啦 -通过引入中间LLM预处理用户输入以提高多任务处理能力
本文探讨了在多任务处理场景下,自然语言指令解析的困境及解决方案。通过增加一个LLM解析层,将复杂的指令拆解为多个明确的步骤,明确操作类型与对象识别,处理任务依赖关系,并将自然语言转化为具体的工具命令,从而提高指令解析的准确性和执行效率。

热门文章

最新文章