当前位置:首页 > 编程教程 > Python技术文章 > flask框架实现连接sqlite3数据库的方法分析

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

  • 发布时间:
  • 作者:码农之家
  • 点击:135

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

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

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

本文实例讲述了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程序设计有所帮助。

以上就是本次给大家分享的关于java的全部知识点内容总结,大家还可以在下方相关文章里找到相关文章进一步学习,感谢大家的阅读和支持。

相关电子书
学习笔记
网友NO.988454

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 ……

网友NO.799418

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. 运行……

网友NO.500120

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……

<
1
>

Copyright 2018-2020 www.xz577.com 码农之家

投诉 / 推广 / 赞助:QQ:520161757