import flask,json,pymysql
from flask import request, jsonify, Response
from datetime import datetime
from flask_cors import CORS db = pymysql.Connect(
host='localhost',
port=3306,
user='root',
passwd='24576946',
db='school',
) cursor = db.cursor() server = flask.Flask(__name__) #允许跨域访问
CORS(server, resources=r'/*')
class JSONResponse(Response):
@classmethod
def force_type(cls, response, environ=None):
if isinstance(response, (list, dict)):
response = jsonify(response)
response.headers['Access-Control-Allow-Credentials'] = 'true'
response.headers['Access-Control-Allow-Origin'] = '*'
response.headers['Access-Control-Allow-Methods'] = 'PUT,GET,POST,DELETE'
response.headers['Access-Control-Allow-Headers'] = 'X-Requested-With'
return super(Response, cls).force_type(response, environ)
server.response_class = JSONResponse #查询成绩列表
@server.route('/grade',methods=['get'])
def grade(): sql = "SELECT id,name,email,point,regdate FROM grade"
cursor.execute(sql)
res = cursor.fetchall() keys = ['id','name','email','point','regdate']
arr = []
for index,item in enumerate(res):
dict1 = {}
for indexd,itemd in enumerate(item):
if keys[indexd] == 'regdate':
print(itemd)
dict1[keys[indexd]] = itemd.strftime('%Y-%m-%d %H:%M')
else:
dict1[keys[indexd]] = itemd
arr.append(dict1)
return json.dumps(arr,ensure_ascii=False) #添加单个成绩
@server.route('/grade',methods=['post'])
def add():
option = json.loads(request.get_data()) if option['name'] == '':
return jsonify({"code": 500,"error":'name不能为空!'}) sql = "INSERT INTO grade (name, email, point, regdate) VALUES ( '%s', '%s', '%d','%s' )"
data = (option['name'], option['email'], option['point'],datetime.strftime(datetime.now(),'%Y-%m-%d %H:%M'))
cursor.execute(sql % data)
db.commit() return jsonify({"code": 200,"data":{"name": option['name'], "email": option['email'], "point": option['point']}})
# add() #查询单个成绩
@server.route('/grade/<int:post_id>',methods=['get'])
def search(post_id):
print(post_id) sql = "SELECT id,name,email,point,regdate FROM grade WHERE id = %s" % (post_id)
cursor.execute(sql)
res = cursor.fetchone() keys = ['id','name','email','point','regdate']
dict1 = {}
for index,item in enumerate(res):
if keys[index] == 'regdate':
dict1[keys[index]] = item.strftime('%Y-%m-%d %H:%M')
else:
dict1[keys[index]] = item return json.dumps(dict1,ensure_ascii=False) #删除单个成绩
@server.route('/grade/<int:post_id>',methods=['post'])
def delete(post_id):
print(post_id) sql = "DELETE FROM grade WHERE id = %s" % (post_id)
cursor.execute(sql)
res = cursor.fetchone() return jsonify({"code":200,"data":'删除成功!'})
# delete(24) #查询老师列表
@server.route('/teacher',methods=['get'])
def getTeacher():
sql = "SELECT id,name,description,student,regdate FROM teacher"
cursor.execute(sql)
res = cursor.fetchall() keys = ['id','name','description','student','regdate']
arr = []
for index,item in enumerate(res):
dict1 = {}
for indexd,itemd in enumerate(item):
if keys[indexd] == 'regdate':
print(itemd)
dict1[keys[indexd]] = itemd.strftime('%Y-%m-%d %H:%M')
else:
dict1[keys[indexd]] = itemd
arr.append(dict1) return json.dumps(arr,ensure_ascii=False) #查询老师有哪几个学生
@server.route('/teacher/<int:teacher_id>',methods=['get'])
def searchStudent(teacher_id):
student_id = request.args.get('studentId')
sql = "SELECT id,name,email,point FROM grade WHERE id = %s" % (student_id)
cursor.execute(sql)
res = cursor.fetchone() keys = ['id','name','email','point']
dict1 = {}
for index,item in enumerate(res):
dict1[keys[index]] = item return json.dumps(dict1,ensure_ascii=False) server.run(port=9003,debug=True,host='192.168.1.195') # 关闭连接
cursor.close()
db.close()

Python基础(API接口测试)的更多相关文章

  1. Python 基础API

    针对python的os库一些API记录,觉得python的命名并不好,很多API看名字,并不知道具体功能是什么 1. os.path.basename() 得到文件名称,不包括路径,例子:/var/t ...

  2. 【2019.5.19】接口测试及python基础(一)

      一.接口 1.什么是接口: 简单的说,接口就是从数据库获取数据. 2.前端和后端: 2.1前端client: 对于web来说,打开的网页,我们所看到的就是前端,前端语言包括html.JS.CSS: ...

  3. python+requests+json 接口测试思路示例

    实际项目中用python脚本实现接口测试的步骤: 1 发送请求,获取响应  >>2 提取响应里的数据,对数据进行必要的处理  >>3 断言响应数据是否与预期一致 以豆瓣接口为例 ...

  4. Python之路3【第一篇】Python基础

    本节内容 Python简介 Python安装 第一个Python程序 编程语言的分类 Python简介 1.Python的由来 python的创始人为吉多·范罗苏姆(Guido van Rossum) ...

  5. Python基础+Pythonweb+Python扩展+Python选修四大专题 超强麦子学院Python35G视频教程

    [保持在百度网盘中的, 可以在观看,嘿嘿 内容有点多,要想下载, 回复后就可以查看下载地址,资源收集不易,请好好珍惜] 下载地址:http://www.fu83.cc/ 感觉文章好,可以小手一抖 -- ...

  6. python基础——定制类

    python基础——定制类 看到类似__slots__这种形如__xxx__的变量或者函数名就要注意,这些在Python中是有特殊用途的. __slots__我们已经知道怎么用了,__len__()方 ...

  7. python 基础知识(一)

    python 基础知识(一) 一.python发展介绍 Python的创始人为Guido van Rossum.1989年圣诞节期间,在阿姆斯特丹,Guido为了打发圣诞节的无趣,决心开发一个新的脚本 ...

  8. Day7 - Python基础7 面向对象编程进阶

    Python之路,Day7 - 面向对象编程进阶   本节内容: 面向对象高级语法部分 经典类vs新式类 静态方法.类方法.属性方法 类的特殊方法 反射 异常处理 Socket开发基础 作业:开发一个 ...

  9. 工程脚本插件方案 - c集成Python基础篇(VC++嵌入Python)

    序: 为什么要集成脚本,怎么在工程中集成Python脚本. 在做比较大型的工程时,一般都会分核心层和业务层.核心层要求实现高效和稳定的基础功能,并提供调用接口供业务层调用的一种标准的框架划分.在实际中 ...

  10. &lt;&lt;Python基础课程&gt;&gt;学习笔记 | 文章13章 | 数据库支持

    备注:本章介绍了比较简单,只是比较使用样品,主要假设是把握连接,利用数据库.和SQLite做演示样本 ------ Python数据库API 为了解决Python中各种数据库模块间的兼容问题,如今已经 ...

随机推荐

  1. mybatis本地缓存&分布式缓存干货分享

    前言:干货记录学习mybatis实际开发中缓存的使用. 环境: springboot2.X + mybatis3.x Mybatis是一款持久层框架,它提供了一级缓存和二级缓存. 名词解释 一级缓存( ...

  2. Java-多态(上)

    什么是多态 同一方法可以根据发送对象的不同而采取多种不同的行为方式 一个对象实际类型是确定的 但指向其引用类型却有很多 注意事项 多态是方法的多态 属性没有多态 父类和子类 有联系 类型转换异常 Cl ...

  3. windos10环境下编译python3版pjsua库

    环境:windows10_x64python3.9_x64pjsua-2.10vs2015 pjsua编译参考这里: https://www.cnblogs.com/MikeZhang/p/pjsip ...

  4. 手把手教你 Docker部署可视化工具Grafana

    一.Grafana的简单介绍 Grafana是开源的.炫酷的可视化监控.分析利器,无论您的数据在哪里,或者它所处的数据库是什么类型,您都可以将它与Grafana精美地结合在一起.它还有丰富的套件供您选 ...

  5. 回归本心QwQ背包问题luogu1776

    今天在这里说一下多重背包问题 对 之前一直没有怎么彻底理解 首先多重背包是什么?这里就不做过多的赘述了 朴素的多重背包的复杂度是\(O(n*m*\sum s[i])\),其中\(s[i]\)是每一件物 ...

  6. 洛谷4208 JSOI2008最小生成树计数(矩阵树定理+高斯消元)

    qwq 这个题目真的是很好的一个题啊 qwq 其实一开始想这个题,肯定是无从下手. 首先,我们会发现,对于无向图的一个最小生成树来说,只有当存在一些边与内部的某些边权值相同的时候且能等效替代的时候,才 ...

  7. MySQL数据库建表命名的坑

    今天建了一张表,表名为--inOut: 然后再使用中发现怎么都是SQL错误: 然后在Navacat上发现 这是一个关键词! 如果非要继续使用,只能这样: 类似的坑还有user等.

  8. appium操作安卓应用所需要的数据准备

    操作系统.系统版本如下所示: desired_caps={} desired_caps["platformName"]="Android" desired_ca ...

  9. FastAPI 学习之路(十五)响应状态码

    系列文章: FastAPI 学习之路(一)fastapi--高性能web开发框架 FastAPI 学习之路(二) FastAPI 学习之路(三) FastAPI 学习之路(四) FastAPI 学习之 ...

  10. for...of 和 for...in 是否可以直接遍历对象,有什么解决方案

    答案: for...of不能直接遍历对象,for  in可以直接遍历对象 原因: for...of需要实现iterator接口,对象没有实现iterator接口 解决: const obj = {a: ...