标签分类
技术文章
当前位置:主页 > 计算机编程 > python > flask框架实现连接sqlite3数据库的方法分析

详解flask框架实现连接sqlite3数据库方法

  • 发布时间:
  • 作者:码农之家原创
  • 点击:118

flask框架实现连接sqlite3数据库的方法分析

这篇文章主要知识点是关于flask框架,sqlite3数据库,flask框架实现连接sqlite3数据库的方法分析,的内容,如果大家想对相关知识点有系统深入的学习,可以参阅以下电子书

Python程序设计开发宝典
  • 类型:Python大小:42.8 MB格式:PDF出版:清华大学出版社作者:董付国
立即下载

更多相关的学习资源可以参阅 程序设计电子书Python电子书、等栏目。

本文实例讲述了flask框架实现连接sqlite3数据库的方法。分享给大家供大家参考,具体如下:

1. 在flask文件夹中新建一个models.py文件用来定义模型,内部代码如下

import sqlite3 #导入sqlite3包
def get_conn():
 #定义该函数用来连接数据库
 return sqlite3.connect("test.db")
class User(object):
 def __init__(self,id,name):
  self.id = id
  self.name = name
 def save(self):
  sql = "insert into user VALUES (?,?)"#sql语句
  conn = get_conn()#连接数据库
  cursor = conn.cursor()#定义一个游标
  cursor.execute(sql,(self.id,self.name))#执行sql语句
  conn.commit()#提交数据库改动
  cursor.close()#关闭游标
  conn.close()#关闭数据库连接
 '''
 staticmethod相当于一个定义在类里面的函数,所以如果一个方法既不跟实例
 相关也不跟特定的类相关,推荐将其定义为一个staticmethod,这样不仅使代
 码一目了然,而且似的利于维护代码。
 '''
 @staticmethod
 def query():
  sql = "select * from user"
  conn = get_conn()
  cursor = conn.cursor()
  rows = cursor.execute(sql)
  users = []
  for row in rows:
   user = User(row[0],row[1])
   users.append(user)
  conn.commit()
  cursor.close()
  conn.close()
  return users
 def __str__(self):
  return 'id:{}--name:{}'.format(self.id,self.name)#注此处的是点不是逗号

2. 在flask文件夹中新建一个manage.py文件

(1)导入flask_script包,导入sqlite3包,导入models.py中定义的模型,导入flask中的应用,所以最终头部代码如下

from flask_script import Manager
from learn_flask_script import app
import sqlite3
from models import User

(2)创建数据库,代码如下

@manager.command
def init_db():
 sql = "create table user (id INT,name TEXT)"
 conn = sqlite3.connect("test.db")
 cursor = conn.cursor()
 cursor.execute(sql)
 conn.commit()
 cursor.close()
 conn.close()

(3)保存数据,代码如下

@manager.command
def save():
 user = User(1,'csdn')
 user.save()

(4)查询数据,代码如下

@manager.command
def query_all():
 users = User.query()
 for user in users:
  print(user)

整体代码如下

from flask_script import Manager
from learn_flask_script import app
import sqlite3
from models import User
manager = Manager(app)
@manager.command
def init_db():
 sql = "create table user (id INT,name TEXT)"
 conn = sqlite3.connect("test.db")
 cursor = conn.cursor()
 cursor.execute(sql)
 conn.commit()
 cursor.close()
 conn.close()
@manager.command
def save():
 user = User(1,'zhangjia')
 user.save()
@manager.command
def query_all():
 users = User.query()
 for user in users:
  print(user)
if __name__ == "__main__":
 manager.run()

3. 在终端中使用命令即可运行数据库的创建,添加以及查询

希望本文所述对大家Python程序设计有所帮助。

以上就是本次给大家分享的全部知识点内容总结,大家还可以在下方相关文章里找到详解vue axios封装请求状态、 vue项目中使用md5加密以及、 spring+springmvc+mybatis整合注、 等python文章进一步学习,感谢大家的阅读和支持。

上一篇:《Python并行编程参考手册》书评、笔记、下载

下一篇:Python如何实现图片拼接

展开 +

收起 -

学习笔记
网友NO.462576

Flask框架Jinjia模板常用语法总结

本文实例总结了Flask框架Jinjia模板常用语法。分享给大家供大家参考,具体如下: 1. 变量表示 {{ argv }} 2. 赋值操作 {% set links = [ ('home',url_for('.home')), ('service',url_for('.service')), ('about',url_for('.about')),] %} 3. if判断 {% if not loop.first %}|{% endif %} 4. for 循环 {% for label,link in links %} {% if not loop.first %}|{% endif %} a href="{{ link }}" rel="external nofollow" {{ label }}/a{% endfor %} 5. 定义测试函数 上面 loop.first 就是一个测试函数,这个我们也可以自定义 定义是在Sample.py 里定义的, current_link 是HTML中可使用测试函数名称(可选) @app.template_test('current_link')def is_current_link(link): return link == request.path HTML中,使用例子 body{% set links = [ ('home',url_for('.home')), ('service',url_for('.service')), ('about',url_for('.about')),] %}nav {% for label,link in links %} {% if not loop.first %}|{% endif %} a href="{% if link is current_link %}# {% else %} {{ link }} {% endif %} "{{ label }}/a {% endfor %}/nav/body 6. 块block Flask强大的地方就可以引用模板,而且非常方便。 这里不得不介绍block这个概念。 模板的文件一般放在 templates 文件夹下,我们这里新建一个HTML文件,存放模板,' base.html ' 在这里面也,编排了整个页面的排版,里面会用到很多 block的占位符 。 每个block都代表一段html语句块,而这些块在哪里定义呢,可以在当前的base.html中……

网友NO.632232

python中Web框架(Flask)的详解(代码示例)

flask flask是一个Python编写的Web 微框架,让我们可以使用Python语言快速实现一个网站或Web服务。 使用flask 当你编写一个函数时,要想每个人都可以使用,需要用到flask来实现这个目标。 导入falsk.Flask类 实例化一个Flask对象 绑定路由 运行flask应用 # 1. 导入Flask类;from flask import Flask# 2. 实例化一个Flask对象;# __name__是模块的名称或者包的名称# 作用: 根据这个参数确定flask应用的路径, 从而快速查找模板和html文件的默认路径;# 模块就是python文件; 包就是目录(跟普通目录多加一个__init__.py);#app = Flask(__name__)# 3-1.基本路由:通过路由绑定一个视图函数# @app.route('/'): 告诉Flask哪个URL才能出发对应的函数, 又称为路由;# 对应定义了一个视图函数, 也就是返回给用户浏览器显示的内容;@app.route('/')def index(): return h1hello world/h1@app.route('/login/')def login(): return login# 4. 运行Flask应用, 可以指定ip和端口;# '0.0.0.0' 所有的IP都可以访问到;app.run('0.0.0.0', 9000) 路由及变量规则 在flask框架中,路由表示用户请求的URL找出其对应的处理函数 常见路由的规则 url的一部分可以标记为变量变量名 flask中路由里面的变量常见类型: int, string, float, path, uuid from flask import Flask, requestapp = Flask(__name__)@app.route('/int:id/comments/')def comment1(id): return Comment id: %s %(id)@app.route('/welc……

网友NO.206402

Flask框架响应、调度方法和蓝图操作实例分析

本文实例讲述了Flask框架响应、调度方法和蓝图操作。分享给大家供大家参考,具体如下: 响应 像现在大部分的互联网应用用的数据传输格式都是JSON,当用户访问一个URL,我们如何通过Flask返回JSON的响应: 普通做法: @app.route("/")def showInfo(): return jsonify({"name":"老王","age":18}) 当我们的应用有大量的URL时,我们需要每次都用jsonify转换一下,不免觉得繁琐。此时会有人说,可以定义一个公共方法,将转换都在这个方法中实现就好了。这也不失为一个可行的方法,还有一种方法让Flask自动帮我们做这些工作: from flask import Response,jsonifyclass JSONResponse(Response): @classmethod def force_type(cls,response,environ=None): if isinstance(response,dict): response = jsonify(response) return super(JSONResponse,cls).force_type(response,environ)app.response_class = JSONResponse@app.route("/")def showInfo(): return {"name":"老王","age":18} 调度方法 flask.views.MethodView 对每个HTTP方法执行不同的函数(映射到对应方法的小写的同名方法上),这对 RESTful API 尤其有用。 from flask.views import MethodViewclass UserAPI(MethodView): def get(self): return jsonify({"method":"get"}) def post(self): return jsonify({"method":"post"})app.add_url_rule("/user",view_func=UserAPI.as_view("userview")) 当用户使用GET或POST请求 http://localhost:5000/user 时,会执行UserAPI中相应get,post函数。 蓝图……

<
1
>

Copyright 2018-2019 xz577.com 码农之家

版权责任说明