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实现数据库增删改查的更多相关文章

  1. 练习 python之数据库增删改查

    # 文件存储时可以这样表示 ## id,name,age,phone,dept,enroll_date# 1,Alex Li,22,13651054608,IT,2013-04-01# 2,Jack ...

  2. python操作mysql数据库增删改查的dbutils实例

    python操作mysql数据库增删改查的dbutils实例 # 数据库配置文件 # cat gconf.py #encoding=utf-8 import json # json里面的字典不能用单引 ...

  3. Python实现mysql数据库增删改查

    利用python操作mysql数据库用法简单,环境配置容易,本文将实现对库增.删.改.查的简易封装!   1. 环境配置 安装第三方包  ,导入模块 mysql.connector  pip inst ...

  4. 数据库学习之数据库增删改查(另外解决Mysql在linux下不能插入中文的问题)(二)

    数据库增删改查 增加 首先我们创建一个数据库user,然后创建一张表employee create table employee( id int primary key auto_increment, ...

  5. Yii2.0高级框架数据库增删改查的一些操作(转)

    yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 --------------------------- ...

  6. 2. MongoDB基本操作 —— 用Mongo.exe操作数据库增删改查

    一.开篇 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由数据库(database).集合(collection).文档对象 ...

  7. go——beego的数据库增删改查

    一直都不理解使用go语言的时候,为什么还要自己去装beego,以为使用go便可以解决所有的问题,结果在朋友的点拨下,才意识到: go与beego的关系就好比是nodejs与thinkjs的关系,因此也 ...

  8. (转)SQLite数据库增删改查操作

    原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...

  9. Yii2.0高级框架数据库增删改查的一些操作

    yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 --------------------------- ...

随机推荐

  1. Linux中bash编程

    bash编程也叫shell编程 预定义变量         $? 最后一次执行的命令的返回状态.如果这个变量的值为0,证明上一个命令正确的执行:如果这个变量返回的值非0(具体是那个数,有命令自己来决定 ...

  2. Mysql索引会失效的几种情况分析(转)

    出处:http://www.jb51.net/article/50649.htm 索引并不是时时都会生效的,比如以下几种情况,将导致索引失效: 1.如果条件中有or,即使其中有条件带索引也不会使用(这 ...

  3. C# Redis Server分布式缓存编程(二)(转)

    出处;http://www.cnblogs.com/davidgu/p/3263485.html 在Redis编程中, 实体和集合类型则更加有趣和实用 namespace Zeus.Cache.Red ...

  4. 如何用word文档在博客里发表文章

    目前大部分的博客作者在用Word写博客这件事情上都会遇到以下3个痛点: 1.所有博客平台关闭了文档发布接口,用户无法使用Word,Windows Live Writer等工具来发布博客.使用Word写 ...

  5. WCF Service 配置文件注释(转)

    <?xml version="1.0" encoding="utf-8" ?> <configuration> <system.S ...

  6. Android各国语言Values文件夹命名规则

    android多国语言文件夹文件汇总如下: 中文(中国):values-zh-rCN 中文(台湾):values-zh-rTW 中文(香港):values-zh-rHK 英语(美国):values-e ...

  7. Tempdb--monitoring and troubleshooting

    TempDB用来存放临时表.全局临时表.表变量以及排序或HASH等操作引发的中间结果集 TempDB在每次实例重启时重新创建,TempDB数据库文件的初始化大小取决于Model数据库的文件大小或显示A ...

  8. Python学习之全局变量与global

    刚学习Python,遇到个问题:为什么有些定义在函数外的变量可以直接被函数使用,有些就不行呢? 如: count = 0 def change(): count += 1 change() # 报错 ...

  9. pod-infrastructure:latest镜像下载失败

    报错一:image pull failed for registry.access.redhat.com/rhel7/pod-infrastructure:latest, this may be be ...

  10. CF553C Love Triangles

    题目链接 题意:给定n个点,给出一些边权为0/1的边,构造完全图,满足对于任何一个三元环,三条边权和为奇.求符合条件的完全图数量,对\(1e9+7\)取模. 分析:其实原题给定的边权是love/hat ...