1、python内置的sqlite3模块,创建数据库中的表,并向表中插入数据,从表中取出所有行,以及输出行的数量。

#!/usr/bin/env python3

#创建SQLite3内存数据库,并创建带有四个属性的sales表

#sqlite3模块,提供了一个轻量级的基于磁盘的数据库,不需要独立的服务器进程

import sqlite3

#使用‘:memory:'在内存中创建了一个数据库,创建了连接对象con来代表数据库

con = sqlite3.connect(':memory:')

#创建表名为sales的表,将这个字符串赋值给query

query = """CREATE TABLE sales

(customer VARCHAR(20),

product VARCHAR(40),

amount FLOAT,

date DATE);"""

#使用连接对象的execute()方法执行query中的SQL命令

con.execute(query)

#使用连接对象的commit()方法将修改提交(保存)到数据库

con.commit()

#向表中插入几行数据

data = [('Richard Lucas','Notepad',2.50,'2019-01-02'),

('Jenny Kim','Binder',4.15,'2019-01-05'),

('Svetlana Crow','Printer',155.75,'2019-02-03'),

('Stephen Randolph','Computer',679.40,'2019-02-20')]

#将插入语句赋给变量statement,?是占位符

statement = "INSERT INTO sales VALUES(?,?,?,?)"

#因为有四个占位符,这里就需要提供一个包含4个值的元组,executemany()方法为data中的每个数据元组执行

#statement中的SQL命令,这里执行了四次insert命令

con.executemany(statement,data)

#将修改保存到数据库

con.commit()

#查询sales表,并将命令结果赋值给一个光标对象cursor,光标对象有execute、executemany、fetchone、

#fetchmany和fetchall方法

cursor = con.execute("SELECT * FROM sales")

#返回结果集中的所有行

rows = cursor.fetchall()

print(rows)

print('………………')

#查询结果中行的数量

row_counter = 0

for row in rows:

print(row)

row_counter += 1

print('………………')

print('Number of rows: %d' % (row_counter))

Spyder右下角打印出来的结果:

[('Richard Lucas', 'Notepad', 2.5, '2019-01-02'), ('Jenny Kim', 'Binder', 4.15, '2019-01-05'), ('Svetlana Crow', 'Printer', 155.75, '2019-02-03'), ('Stephen Randolph', 'Computer', 679.4, '2019-02-20')]

………………

('Richard Lucas', 'Notepad', 2.5, '2019-01-02')

('Jenny Kim', 'Binder', 4.15, '2019-01-05')

('Svetlana Crow', 'Printer', 155.75, '2019-02-03')

('Stephen Randolph', 'Computer', 679.4, '2019-02-20')

………………

Number of rows: 4

2、python内置的sqlite3模块,向表中插入新纪录

名称为“CSV测试数据.csv”的数据源:

将本地“CSV测试数据.csv”的数据导入到本地数据库football_game.db中:

#!/usr/bin/env python3

#创建SQLite3内存数据库,并创建带有四个属性的sales表

#sqlite3模块,提供了一个轻量级的基于磁盘的数据库,不需要独立的服务器进程

import sqlite3

import csv

input_file = "F://python入门//数据1//CSV测试数据.csv"

#为一个简单的本地数据库football_game.db创建连接,football_game.db为数据库名称

con = sqlite3.connect('football_game.db')

#创建了一个光标

c = con.cursor()

#如果表名存在,则删除它

drop_table = """DROP TABLE IF EXISTS football_game;"""

c.execute(drop_table)

con.commit()

#创建表名为football_game的表,将这个字符串赋值给create_table

create_table = """CREATE TABLE IF NOT EXISTS football_game

(name VARCHAR(20),

sex VARCHAR(10),

age INT,

score INT,

device_number VARCHAR(20),

cost VARCHAR(20));"""

#使用连接对象的execute()方法执行create_table中的SQL命令

c.execute(create_table)

#使用连接对象的commit()方法将修改提交(保存)到数据库

con.commit()

#从CSV格式的输入文件中读取要加载到数据库中的数据,创建file_reader对象,用于存储CSV中的数据集

file_reader = csv.reader(open(input_file,'r'),delimiter=',')

#从输入文件中读入第一行

header = next(file_reader,None)

#将输入的所有数据进行循环,先是每行循环,再是每列循环

for row in file_reader:

data = []

for column_index in range(len(header)):

data.append(row[column_index])

print(data)

c.execute("INSERT INTO football_game VALUES(?,?,?,?,?,?)",data)

#将修改保存到数据库

con.commit()

print('………………')

#执行选择所有数据的SQL

output = c.execute("SELECT * FROM football_game")

#返回结果集中的所有行,返回的是一个大的列表

rows = output.fetchall()

print(rows)

print('………………')

for row in rows:

output = []

for column_index in range(len(row)):

output.append(str(row[column_index]))

print(output)

Spyder右下角打印出来的结果:

['李刚', '男', '32', '567', '18512349553', '$500.00 ']

['王红', '女', '54', '423', '18256785181', '$750.00 ']

['孙晓', '女', '25', '457', '13698762112', '$250.00 ']

['郭亮', '男', '65', '350', '18654320816', '$125.00 ']

['高英', '女', '15', '390', '18511113141', '$815.00 ']

………………

[('李刚', '男', 32, 567, '18512349553', '$500.00 '), ('王红', '女', 54, 423, '18256785181', '$750.00 '), ('孙晓', '女', 25, 457, '13698762112', '$250.00 '), ('郭亮', '男', 65, 350, '18654320816', '$125.00 '), ('高英', '女', 15, 390, '18511113141', '$815.00 ')]

………………

['李刚', '男', '32', '567', '18512349553', '$500.00 ']

['王红', '女', '54', '423', '18256785181', '$750.00 ']

['孙晓', '女', '25', '457', '13698762112', '$250.00 ']

['郭亮', '男', '65', '350', '18654320816', '$125.00 ']

['高英', '女', '15', '390', '18511113141', '$815.00 ']

3、python内置的sqlite3模块,更新数据表中的记录

名称为“CSV测试数据.csv”的数据源:

更新表中的记录:

#!/usr/bin/env python3

#创建SQLite3内存数据库,并创建带有四个属性的sales表

#sqlite3模块,提供了一个轻量级的基于磁盘的数据库,不需要独立的服务器进程

import sqlite3

import csv

input_file = "F://python入门//数据1//CSV测试数据.csv"

#使用‘:memory:'在内存中创建了一个数据库,创建了连接对象con来代表数据库

con = sqlite3.connect(':memory:')

#创建表名为sales的表,将这个字符串赋值给query

query = """CREATE TABLE IF NOT EXISTS sales

(customer VARCHAR(20),

product VARCHAR(40),

amount FLOAT,

date DATE);"""

#使用连接对象的execute()方法执行query中的SQL命令

con.execute(query)

#使用连接对象的commit()方法将修改提交(保存)到数据库

con.commit()

#向表中插入几行数据

data = [('Richard Lucas','Notepad',2.50,'2019-01-02'),

('Jenny Kim','Binder',4.15,'2019-01-05'),

('Svetlana Crow','Printer',155.75,'2019-02-03'),

('Stephen Randolph','Computer',679.40,'2019-02-20')]

#for tuple in data:

# print(tuple)

#将插入语句赋给变量statement,?是占位符

statement = "INSERT INTO sales VALUES(?,?,?,?)"

#因为有四个占位符,这里就需要提供一个包含4个值的元组,executemany()方法为data中的每个数据元组执行

#statement中的SQL命令,这里执行了四次insert命令

con.executemany(statement,data)

#将修改保存到数据库

con.commit()

#读取CSV文件并更新特定的行

file_reader = csv.reader(open(input_file,'r'),delimiter=',')

#从输入文件中读入第一行

header = next(file_reader,None)

#将输入的所有数据进行循环,先是每行循环,再是每列循环

for row in file_reader:

data = []

for column_index in range(len(header)):

data.append(row[column_index])

con.execute("UPDATE sales SET amount=?,date=? where customer=?;",data)

#将修改保存到数据库

con.commit()

#查询sales表,并将命令结果赋值给一个光标对象cursor,光标对象有execute、executemany、fetchone、

#fetchmany和fetchall方法

cursor = con.execute("SELECT * FROM sales")

#返回结果集中的所有行

rows = cursor.fetchall()

print(rows)

print('………………')

for row in rows:

output = []

for column_index in range(len(row)):

output.append(str(row[column_index]))

print(output)

Spyder右下角打印出来的结果:

[('Richard Lucas', 'Notepad', 4.25, '2019-11-05'), ('Jenny Kim', 'Binder', 6.75, '2019-12-05'), ('Svetlana Crow', 'Printer', 155.75, '2019-02-03'), ('Stephen Randolph', 'Computer', 679.4, '2019-02-20')]

………………

['Richard Lucas', 'Notepad', '4.25', '2019-11-05']

['Jenny Kim', 'Binder', '6.75', '2019-12-05']

['Svetlana Crow', 'Printer', '155.75', '2019-02-03']

['Stephen Randolph', 'Computer', '679.4', '2019-02-20']

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

python自带sqlite_Python使用sqlite3模块内置数据库相关推荐

  1. Python模块内置函数

    一.任务描述   本实验任务主要完成对Python模块内置函数进行一些基本操作,通过完成本实验任务,要求学生熟练掌握Python模块内置函数,并对Python内置函数的基本操作进行整理并填写工作任务报 ...

  2. Python基础092:Python内置数据库: sqlite3

    Python内置数据库: sqlite3 SQLite简介 前置知识点复习 python中实践 sqlite 查询记录 注意事项 总结 SQLite简介 SQLite是一种嵌入式数据库,它的数据库就是 ...

  3. Python(8):模块内置变量

    写在前面 文章目录 模块内置变量 常用内置变量 __name__变量 __package__变量 __file__变量 __doc__变量 专栏目录 模块内置变量 常用内置变量 __name__变量 ...

  4. Python中lambda详解(包括内置函数map、reduce、filter、sorted、max)

    文章目录 一.lambda是什么? 1.lambda语法 2.语法详解 二.lambda的使用 1.定义 2.调用 3.替换 4.作返回值 三.lambda作参数 1.map函数 2.reduce函数 ...

  5. Python爬虫-Scrapy框架(四)- 内置爬虫文件 - 4.2 初探Crawl Spider

    Python爬虫-Scrapy框架(四)- 内置爬虫文件 - 4.2 初探Crawl Spider 写在前面 初探Crawl Spider 创建Crawl Spider项目 对比Basic与Crawl ...

  6. python的四种内置数字类型_浅析Python数字类型和字符串类型的内置方法

    一.数字类型内置方法 1.1 整型的内置方法 作用 描述年龄.号码.id号 定义方式 x = 10 x = int('10') x = int(10.1) x = int('10.1') # 报错 内 ...

  7. [转载] Python列表排序 list.sort方法和内置函数sorted

    参考链接: Python中的函数 Python列表排序 list.sort方法和内置函数sorted 很多时候我们获取到一个列表后,这个列表并不满足我们的需求,我们需要的是一个有特殊顺序的列表. 这时 ...

  8. python内置类型方法_浅析Python数字类型和字符串类型的内置方法

    一.数字类型内置方法 1.1 整型的内置方法 作用 描述年龄.号码.id号 定义方式 x = 10 x = int('10') x = int(10.1) x = int('10.1') # 报错 内 ...

  9. Python列表排序 list.sort方法和内置函数sorted

    Python列表排序 list.sort方法和内置函数sorted 很多时候我们获取到一个列表后,这个列表并不满足我们的需求,我们需要的是一个有特殊顺序的列表. 这时候就可以使用list.sort方法 ...

最新文章

  1. [转]有关IIS的虚拟目录的控制总结
  2. APK文件的解包打包和修改
  3. 计算机密码都有什么用,要不是他,你根本不会忘记密码。
  4. spring学习网址(博客)
  5. Git rebase 和 Git merge 的区别,你知道吗?
  6. c语言保存后怎么打开文件,保存打开文件之后,怎么也不能在显示函数中出来。。...
  7. 美国高校开源迄今为止最大新冠肺炎CT数据集
  8. pdf打印显示spoolsv.exe-应用程序错误的原因和解决方法
  9. Linux20180502 六周第四次课(5月2日)
  10. 《回答sort一例》-linux命令五分钟系列之二十八
  11. 【Spark篇】---SparkStreaming算子操作transform和updateStateByKey
  12. 离线安装docker镜像
  13. Gradle在Android中的基本使用
  14. mybatis mysql 注解_Mybatis注解的使用
  15. kaggle:Costa Rican Household Poverty Level Prediction(1)DEA
  16. cad如何生成kml文件_如何制作KML文件?
  17. 镇楼篇--转行初入IT的心路历程
  18. 巴特沃斯滤波器 python代码
  19. qlikview中日期问题的两个小结
  20. git push的详细使用

热门文章

  1. 虚拟机蓝屏:KMODE EXCEPTION NOT HANDLED
  2. 耦合式是什么意思_什么是耦合?
  3. 通讯录的实现(另附完整源码)
  4. [SWPUCTF 2021 新生赛] 第三波放题
  5. 懒人HTML5笔记-1
  6. 微软亚洲研究院电话面试
  7. Spring boot Mybatis传入对象中有数组array时使用${}、#{}批量映射存储多个字段
  8. Prometheus_additional传统配置
  9. 触摸屏毛笔签名软件下载
  10. 2022化工自动化控制仪表操作证考试题库及答案