python实现数据库增删改查
column_dic = {"id": 0, "name": 1, "age": 2, "phone": 3, "job": 4}
def get_show_list(col_condition): # "select age,name"
"""
获取要展示的列名
:param col_condition: 用户输入的select条件
:return: 列名组成的列表
"""
col_info_list = col_condition.strip().split("select") # ["", "age,name"]
col_info_list = [col_info_item for col_info_item in col_info_list if col_info_item.strip()] # ["age,name"]
if col_info_list:
col_info = col_info_list[0].strip() # "age,name"
if "*" in col_info:
return column_dic.keys()
elif col_info:
ret = col_info.split(",") # [" age ","name"]
return [item.strip() for item in ret] # ["age","name"]
else:
print(col_info)
def filter_handler(operate, con): # ">" , "age>22"
selected_list = []
col, val = con.split(operate)
col = col.strip()
val = val.strip()
judge = "int(line_list[column_dic[col]]) %s int(val)" % operate if operate == "<" or operate == ">" \
else "line_list[column_dic[col]] %s val" % operate
f = open("student", encoding="utf-8")
for line in f:
line_list = line.strip().split(",")
if eval(judge):
selected_list.append(line_list)
f.close()
return selected_list
def get_selected_line(con): # con = "age>22"
"""
获取要查找的行,并将每一行作为列表项存储到selected_list
:param con:
:return:
"""
if ">" in con:
selected_list = filter_handler(">", con)
elif "<" in con:
selected_list = filter_handler("<", con)
elif "=" in con:
selected_list = filter_handler("==", con.replace("=", '=='))
elif "like" in con:
selected_list = filter_handler("in", con)
return selected_list
def show(selected_list, show_list):
for selected_item in selected_list:
for col in show_list:
print(selected_item[column_dic[col]], end=" ")
print()
condition = input(">>>") # "select age,name where age>22"
ret = condition.split('where') # ["select age,name", "age>22"]
con = ret[1].strip() # "age>22"
show_list = get_show_list(ret[0]) # ["name", "age"]
selected_list = get_selected_line(con)
show(selected_list, show_list)
python实现数据库增删改查的更多相关文章
- 练习 python之数据库增删改查
# 文件存储时可以这样表示 ## id,name,age,phone,dept,enroll_date# 1,Alex Li,22,13651054608,IT,2013-04-01# 2,Jack ...
- python操作mysql数据库增删改查的dbutils实例
python操作mysql数据库增删改查的dbutils实例 # 数据库配置文件 # cat gconf.py #encoding=utf-8 import json # json里面的字典不能用单引 ...
- Python实现mysql数据库增删改查
利用python操作mysql数据库用法简单,环境配置容易,本文将实现对库增.删.改.查的简易封装! 1. 环境配置 安装第三方包 ,导入模块 mysql.connector pip inst ...
- 数据库学习之数据库增删改查(另外解决Mysql在linux下不能插入中文的问题)(二)
数据库增删改查 增加 首先我们创建一个数据库user,然后创建一张表employee create table employee( id int primary key auto_increment, ...
- Yii2.0高级框架数据库增删改查的一些操作(转)
yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 --------------------------- ...
- 2. MongoDB基本操作 —— 用Mongo.exe操作数据库增删改查
一.开篇 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由数据库(database).集合(collection).文档对象 ...
- go——beego的数据库增删改查
一直都不理解使用go语言的时候,为什么还要自己去装beego,以为使用go便可以解决所有的问题,结果在朋友的点拨下,才意识到: go与beego的关系就好比是nodejs与thinkjs的关系,因此也 ...
- (转)SQLite数据库增删改查操作
原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...
- Yii2.0高级框架数据库增删改查的一些操作
yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 --------------------------- ...
随机推荐
- Java 设计模式系列(十五)迭代器模式(Iterator)
Java 设计模式系列(十五)迭代器模式(Iterator) 迭代器模式又叫游标(Cursor)模式,是对象的行为模式.迭代子模式可以顺序地访问一个聚集中的元素而不必暴露聚集的内部表象(interna ...
- asp.net mvc 3高级编程文摘
第一章 入门 M:模型,组类,描述了要处理的数据以及修改和操作数据的业务规则 V:视图,定义应用程序用户界面的显示方式 C:控制器,一组类,用于处理来自用户,整个应用程序流以及特定应用程序逻辑的通信 ...
- “undefined JNI_GetCreatedJavaVM”和“File format not recognized”错误原因分析
如果编译时,报如下所示错误:../../third-party/hadoop/lib/libhdfs.a(jni_helper.c.o): In function `getGlobalJNIEnv': ...
- C# FTPClientHelper共公类 实现文件上传,目录操作,下载等动作
文档说明 本文档使用Socket通信方式来实现ftp文件的上传下载等命令的执行 1.基本介绍 由于最近的项目是客户端的程序,需要将客户端的图片文件[切图]-[打包]-[ftp上传],现在就差最后一步了 ...
- Android-openFileInput openFileOutput
Android设计了一套可以操作自身APP目录文件对API openFileInput openFileOutput,读取只需传入文件名,写入需要传入文件名 与 权限模式 界面: 布局代码: < ...
- 2.自己的Github注册流程
一开始申请Github,说实话我真的不知道它是什么东西,而且有什么用途.然后我就用360百科搜索了一下有关它的介绍:. 而说明的是Git是一个分布式的版本控制系统.然后我进入官方网站进行账号注册,而注 ...
- php的循环与引用的一个坑
上代码 $arr = array( 'a'=> 'a11', 'b'=> 'b22', 'c'=> 'c33', ); foreach ($arr as $k=>&$v ...
- 简单的ListView中item图片异步加载
前言: 在android开发当中,从目标地址获取图片往往都是采用异步加载的方法.当完全加载完图片后在进行显示,也有些是直接将加载的图片一点一点的显示出来. 这两个区别只是对流的处理不同而已.现 ...
- PYQT4 Python GUI 编写与 打包.exe程序
工作中需要开发一个小工具,简单的UI界面可以很好的提高工具的实用性,由此开启了我的第一次GUI开发之旅,下面将自己学习的心得记录一下,也做为学习笔记吧!!! 参考:http://www.qaulau. ...
- Vsual Studio 高版本打开低版本项目的方法
https://www.cnblogs.com/jmliao/p/5594179.html