이 기사는 Python을 사용하여 직원 정보 테이블을 만드는 방법에 대한 예제 코드를 제공합니다. 이는 특정 참조 가치가 있으므로 도움이 될 수 있습니다.
이것은 포괄적인 연습 문제이며 요구 사항은 다음과 같습니다.
직원 정보 테이블을 생성합니다. 형식은 다음과 같습니다.
#字段1,字段2,字段3,字段4,字段5 #1,*** ,*** , *******,*** #2,***, ***, *******,*** #3,*** ,*** , *****, ***
요구 사항은 조건문을 기반으로 쿼리할 수 있으며 형식은 선택 입니다. 여기서 명령 공백으로 구분됩니다
def emp(): lis_res = [[],[],[],[],[]] #定义最终存储数据的列表 with open('yuangong','r',encoding='utf-8') as f: cha = input('请输入查询语句,格式为:select *** where *** > ***').strip() lis = cha.split(' ')#定义存放输入语句的列表 n = [] #n表示符合查询变量的字符串所在列表位置 if lis[0] == 'select' and lis[2] == 'where':#设定关键字条件 lis1 = lis[1].split(',')#定义查询元素的列表 lis_title = f.readline().split(',') #文件中第一行为字段名 lis_title = [s.strip() for s in lis_title]#列表推导式,去掉每个元素两边的空格 for v in lis1:#循环遍历要查询的字段是否在文件中 if v in lis_title: n.append(lis_title.index(v)) if '*' in lis[1]:n=[0,1,2,3,4]#定义使用*模糊查询 if n == []: #如果字段不存在则退出程序 print('查询的字段不存在') return if lis[4] == '>':#检查条件语句是否是大于号 if lis[3] in lis_title: #字段是否包含条件语句 m = lis_title.index(lis[3]) #m表示符合条件语句的字符串所在列表位置 else: print('字段不含有该条件') return for v in f: lis_f = v.split(',')#把取出来的每条数据都转化成列表 lis_f = [s.strip() for s in lis_f] #列表推导式,去掉每个元素两边的空格 if lis_f[m].isdigit() and lis[5].isdigit():#检查条件是否都为数字 if int(lis_f[m]) > int(lis[5]): for i in n:#如果条件成立则把结果追加到lis_res中 lis_res[i].append(lis_f[i]) else:print('无法进行比较') elif lis[4] == '<':#检查条件语句是否是大于号 if lis[3] in lis_title: #字段是否包含条件语句 m = lis_title.index(lis[3]) #m表示符合条件语句的字符串所在列表位置 else: print('字段不含有该条件') return for v in f: lis_f = v.split(',')#把取出来的每条数据都转化成列表 lis_f = [s.strip() for s in lis_f] #列表推导式,去掉每个元素两边的空格 if lis_f[m].isdigit() and lis[5].isdigit():#检查条件是否都为数字 if int(lis_f[m]) < int(lis[5]): for i in n:#如果条件成立则把结果追加到lis_res中 lis_res[i].append(lis_f[i]) else:print('无法进行比较') elif lis[4] == '=':#检查条件语句是否是大于号 if lis[3] in lis_title: #字段是否包含条件语句 m = lis_title.index(lis[3]) #m表示符合条件语句的字符串所在列表位置 else: print('字段不含有该条件') return for v in f: lis_f = v.split(',')#把取出来的每条数据都转化成列表 lis_f = [s.strip() for s in lis_f] #列表推导式,去掉每个元素两边的空格 if lis_f[m] == lis[5]: for i in n:#如果条件成立则把结果追加到lis_res中 lis_res[i].append(lis_f[i]) elif lis[4] == 'like':#定义like模糊搜索 if lis[3]in lis_title: m = lis_title.index(lis[3]) #m表示符合条件语句的字符串所在列表位置 else: print('字段不含有该条件') return for v in f: lis_f = v.split(',')#把取出来的每条数据都转化成列表 lis_f = [s.strip() for s in lis_f] #列表推导式,去掉每个元素两边的空格 if lis[5] in lis_f[m]: for i in n: lis_res[i].append(lis_f[i]) else:print('请以空格将各个名字隔开') else:print('请输入正确的指令') if n!= []:#防止乱输指令后报错 for i in range(len(lis_res[n[0]])):#输出结果 for k in n: print(lis_res[k][i],end=' ') print('\n',end='') emp()
请输入查询语句,格式为:select *** where *** > ***select * where phone like 188 1 tom 25 18888888888 it
위 내용은 Python을 사용하여 직원 정보 테이블을 생성하는 예제 코드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!