利用python模拟sql语句对员工表格进行增删改查
发布时间 - 2026-01-11 02:11:45 点击率:次本文主要给大家介绍了关于python模拟sql语句对员工表格进行增删改查的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍:

具体需求:
员工信息表程序,实现增删改查操作:
可进行模糊查询,语法支持下面3种:
select name,age from staff_data where age > 22 多个查询参数name,age 用','分割
select * from staff_data where dept = 人事
select * from staff_data where enroll_date like 2013
查到的信息,打印后,最后面还要显示查到的条数
可创建新员工纪录,以phone做唯一键,phone存在即提示,staff_id需自增,添加多个记录record1/record2中间用'/'分割
insert into staff_data values record1/record2
可删除指定员工信息纪录,输入员工id,即可删除
delete from staff_data where staff_id>=5andstaff_id<=10
可修改员工信息,语法如下:
update staff_table set dept=Market,phone=13566677787 where dept = 运维 多个set值用','分割
使用re模块,os模块,充分使用函数精简代码,熟练使用 str.split()来解析格式化字符串
由于,sql命令中的几个关键字符串有一定规律,只出现一次,并且有顺序!!!
按照key_lis = ['select', 'insert', 'delete', 'update', 'from', 'into', 'set', 'values', 'where', 'limit']的元素顺序分割sql.
分割元素作为sql_dic字典的key放进字典中.分割后的列表为b,如果len(b)>1,说明sql字符串中含有分割元素,同时b[0]对应上一个分割元素的值,b[-1]为下一次分割对象!
这样不断迭代直到把sql按出现的所有分割元素分割完毕,但注意这里每次循环都是先分割后赋值!!!当前分割元素比如'select'对应的值,需要等到下一个分割元素
比如'from'执行分割后的列表b,其中b[0]的值才会赋值给sql_dic['select'] ,所以最后一个分割元素的值,不能通过上述循环来完成,必须先处理可能是最后一个分割元素,再正常循环!!
在这sql语句中,有可能成为最后一个分割元素的 'limit' ,'values', 'where', 按优先级别,先处理'limit' ,再处理'values'或 'where'.....
处理完得到sql_dic后,就是你按不同命令执行,对数据文件的增删改查,最后返回处理结果!!
示例代码
# _*_coding:utf-8_*_
# Author:Jaye He
import re
import os
def sql_parse(sql, key_lis):
'''
解析sql命令字符串,按照key_lis列表里的元素分割sql得到字典形式的命令sql_dic
:param sql:
:param key_lis:
:return:
'''
sql_list = []
sql_dic = {}
for i in key_lis:
b = [j.strip() for j in sql.split(i)]
if len(b) > 1:
if len(sql.split('limit')) > 1:
sql_dic['limit'] = sql.split('limit')[-1]
if i == 'where' or i == 'values':
sql_dic[i] = b[-1]
if sql_list:
sql_dic[sql_list[-1]] = b[0]
sql_list.append(i)
sql = b[-1]
else:
sql = b[0]
if sql_dic.get('select'):
if not sql_dic.get('from') and not sql_dic.get('where'):
sql_dic['from'] = b[-1]
if sql_dic.get('select'):
sql_dic['select'] = sql_dic.get('select').split(',')
if sql_dic.get('where'):
sql_dic['where'] = where_parse(sql_dic.get('where'))
return sql_dic
def where_parse(where):
'''
格式化where字符串为列表where_list,用'and', 'or', 'not'分割字符串
:param where:
:return:
'''
casual_l = [where]
logic_key = ['and', 'or', 'not']
for j in logic_key:
for i in casual_l:
if i not in logic_key:
if len(i.split(j)) > 1:
ele = i.split(j)
index = casual_l.index(i)
casual_l.pop(index)
casual_l.insert(index, ele[0])
casual_l.insert(index+1, j)
casual_l.insert(index+2, ele[1])
casual_l = [k for k in casual_l if k]
where_list = three_parse(casual_l, logic_key)
return where_list
def three_parse(casual_l, logic_key):
'''
处理临时列表casual_l中具体的条件,'staff_id>5'-->['staff_id','>','5']
:param casual_l:
:param logic_key:
:return:
'''
where_list = []
for i in casual_l:
if i not in logic_key:
b = i.split('like')
if len(b) > 1:
b.insert(1, 'like')
where_list.append(b)
else:
key = ['<', '=', '>']
new_lis = []
opt = ''
lis = [j for j in re.split('([=<>])', i) if j]
for k in lis:
if k in key:
opt += k
else:
new_lis.append(k)
new_lis.insert(1, opt)
where_list.append(new_lis)
else:
where_list.append(i)
return where_list
def sql_action(sql_dic, title):
'''
把解析好的sql_dic分发给相应函数执行处理
:param sql_dic:
:param title:
:return:
'''
key = {'select': select,
'insert': insert,
'delete': delete,
'update': update}
res = []
for i in sql_dic:
if i in key:
res = key[i](sql_dic, title)
return res
def select(sql_dic, title):
'''
处理select语句命令
:param sql_dic:
:param title:
:return:
'''
with open('staff_data', 'r', encoding='utf-8') as fh:
filter_res = where_action(fh, sql_dic.get('where'), title)
limit_res = limit_action(filter_res, sql_dic.get('limit'))
search_res = search_action(limit_res, sql_dic.get('select'), title)
return search_res
def insert(sql_dic, title):
'''
处理insert语句命令
:param sql_dic:
:param title:
:return:
'''
with open('staff_data', 'r+', encoding='utf-8') as f:
data = f.readlines()
phone_list = [i.strip().split(',')[4] for i in data]
ins_count = 0
if not data:
new_id = 1
else:
last = data[-1]
last_id = int(last.split(',')[0])
new_id = last_id+1
record = sql_dic.get('values').split('/')
for i in record:
if i.split(',')[3] in phone_list:
print('\033[1;31m%s 手机号已存在\033[0m' % i)
else:
new_record = '%s,%s\n' % (str(new_id), i)
f.write(new_record)
new_id += 1
ins_count += 1
f.flush()
return ['insert successful'], [str(ins_count)]
def delete(sql_dic, title):
'''
处理delete语句命令
:param sql_dic:
:param title:
:return:
'''
with open('staff_data', 'r', encoding='utf-8') as r_file,\
open('staff_data_bak', 'w', encoding='utf-8') as w_file:
del_count = 0
for line in r_file:
dic = dict(zip(title.split(','), line.split(',')))
filter_res = logic_action(dic, sql_dic.get('where'))
if not filter_res:
w_file.write(line)
else:
del_count += 1
w_file.flush()
os.remove('staff_data')
os.rename('staff_data_bak', 'staff_data')
return ['delete successful'], [str(del_count)]
def update(sql_dic, title):
'''
处理update语句命令
:param sql_dic:
:param title:
:return:
'''
set_l = sql_dic.get('set').strip().split(',')
set_list = [i.split('=') for i in set_l]
update_count = 0
with open('staff_data', 'r', encoding='utf-8') as r_file,\
open('staff_data_bak', 'w', encoding='utf-8') as w_file:
for line in r_file:
dic = dict(zip(title.split(','), line.strip().split(',')))
filter_res = logic_action(dic, sql_dic.get('where'))
if filter_res:
for i in set_list:
k = i[0]
v = i[-1]
dic[k] = v
line = [dic[i] for i in title.split(',')]
update_count += 1
line = ','.join(line)+'\n'
w_file.write(line)
w_file.flush()
os.remove('staff_data')
os.rename('staff_data_bak', 'staff_data')
return ['update successful'], [str(update_count)]
def where_action(fh, where_list, title):
'''
具体处理where_list里的所有条件
:param fh:
:param where_list:
:param title:
:return:
'''
res = []
if len(where_list) != 0:
for line in fh:
dic = dict(zip(title.split(','), line.strip().split(',')))
if dic['name'] != 'name':
logic_res = logic_action(dic, where_list)
if logic_res:
res.append(line.strip().split(','))
else:
res = [i.split(',') for i in fh.readlines()]
return res
pass
def logic_action(dic, where_list):
'''
判断数据文件中每一条是否符合where_list条件
:param dic:
:param where_list:
:return:
'''
logic = []
for exp in where_list:
if type(exp) is list:
exp_k, opt, exp_v = exp
if exp[1] == '=':
opt = '=='
logical_char = "'%s'%s'%s'" % (dic[exp_k], opt, exp_v)
if opt != 'like':
exp = str(eval(logical_char))
else:
if exp_v in dic[exp_k]:
exp = 'True'
else:
exp = 'False'
logic.append(exp)
res = eval(' '.join(logic))
return res
def limit_action(filter_res, limit_l):
'''
用列表切分处理显示符合条件的数量
:param filter_res:
:param limit_l:
:return:
'''
if limit_l:
index = int(limit_l[0])
res = filter_res[:index]
else:
res = filter_res
return res
def search_action(limit_res, select_list, title):
'''
处理需要查询并显示的title和相应数据
:param limit_res:
:param select_list:
:param title:
:return:
'''
res = []
fields_list = title.split(',')
if select_list[0] == '*':
res = limit_res
else:
fields_list = select_list
for data in limit_res:
dic = dict(zip(title.split(','), data))
r_l = []
for i in fields_list:
r_l.append((dic[i].strip()))
res.append(r_l)
return fields_list, res
if __name__ == '__main__':
with open('staff_data', 'r', encoding='utf-8') as f:
title = f.readline().strip()
key_lis = ['select', 'insert', 'delete', 'update', 'from', 'into', 'set', 'values', 'where', 'limit']
while True:
sql = input('请输入sql命令,退出请输入exit:').strip()
sql = re.sub(' ', '', sql)
if len(sql) == 0:continue
if sql == 'exit':break
sql_dict = sql_parse(sql, key_lis)
fields_list, fields_data = sql_action(sql_dict, title)
print('\033[1;33m结果如下:\033[0m')
print('-'.join(fields_list))
for data in fields_data:
print('-'.join(data))
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
# python
# sql语句
# 写sql语句
# 增删改查
# 多个
# 请输入
# 都是
# 几个
# 切分
# 相关内容
# 有可能
# 在这
# 才会
# 有一定
# 给大家
# 这篇文章
# 谢谢大家
# 来完成
# 必须先
# 符合条件
# 一键
# 是否符合
# 条数
# 迭代
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Windows10如何更改计算机工作组_Win10系统属性修改Workgroup
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
如何用PHP快速搭建高效网站?分步指南
如何确认建站备案号应放置的具体位置?
jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】
如何用虚拟主机快速搭建网站?详细步骤解析
JavaScript如何实现音频处理_Web Audio API如何工作?
Laravel如何保护应用免受CSRF攻击?(原理和示例)
如何用PHP工具快速搭建高效网站?
Mybatis 中的insertOrUpdate操作
php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】
浅析上传头像示例及其注意事项
如何确保西部建站助手FTP传输的安全性?
Laravel如何升级到最新版本?(升级指南和步骤)
iOS正则表达式验证手机号、邮箱、身份证号等
如何在自有机房高效搭建专业网站?
免费视频制作网站,更新又快又好的免费电影网站?
VIVO手机上del键无效OnKeyListener不响应的原因及解决方法
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势
Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制
装修招标网站设计制作流程,装修招标流程?
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
利用vue写todolist单页应用
,交易猫的商品怎么发布到网站上去?
制作公司内部网站有哪些,内网如何建网站?
免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?
如何在局域网内绑定自建网站域名?
Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境
Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
JavaScript如何实现错误处理_try...catch如何捕获异常?
Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置
Python图片处理进阶教程_Pillow滤镜与图像增强
Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能
如何快速搭建高效简练网站?
如何构建满足综合性能需求的优质建站方案?
Laravel怎么清理缓存_Laravel optimize clear命令详解
如何在Windows虚拟主机上快速搭建网站?
Laravel Fortify是什么,和Jetstream有什么关系
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
使用PHP下载CSS文件中的所有图片【几行代码即可实现】
Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性
laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析
LinuxShell函数封装方法_脚本复用设计思路【教程】
Laravel软删除怎么实现_Laravel Eloquent SoftDeletes功能使用教程
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
如何用JavaScript实现文本编辑器_光标和选区怎么处理
Win11怎么开启自动HDR画质_Windows11显示设置HDR选项
Laravel如何优雅地处理服务层_在Laravel中使用Service层和Repository层

