python与sqlite3_SQLite3 of python

1 #-*- coding: utf-8 -*-

2 '''

3 使用 url = "http://www.zuihaodaxue.cn/zuihaodaxuepaiming2016.html" 的数据进行SQLite3数据库的练习使用4 @author: bpf5 '''

6

7 importsqlite38 from pandas importDataFrame9 importre10

11 classSQL_method:12 '''

13 function: 可以实现对数据库的基本操作14 '''

15 def __init__(self, dbName, tableName, data, columns, COLUMNS, Read_All=True):16 '''

17 function: 初始化参数18 dbName: 数据库文件名19 tableName: 数据库中表的名称20 data: 从csv文件中读取且经过处理的数据21 columns: 用于创建数据库,为表的第一行22 COLUMNS: 用于数据的格式化输出,为输出的表头23 Read_All: 创建表之后是否读取出所有数据24 '''

25 self.dbName =dbName26 self.tableName =tableName27 self.data =data28 self.columns =columns29 self.COLUMNS =COLUMNS30 self.Read_All =Read_All31

32 defcreatTable(self):33 '''

34 function: 创建数据库文件及相关的表35 '''

36 #连接数据库

37 connect =sqlite3.connect(self.dbName)38 #创建表

39 connect.execute("CREATE TABLE {}({})".format(self.tableName, self.columns))40 #提交事务

41 connect.commit()42 #断开连接

43 connect.close()44

45 defdestroyTable(self):46 '''

47 function: 删除数据库文件中的表48 '''

49 #连接数据库

50 connect =sqlite3.connect(self.dbName)51 #删除表

52 connect.execute("DROP TABLE {}".format(self.tableName))53 #提交事务

54 connect.commit()55 #断开连接

56 connect.close()57

58 definsertDataS(self):59 '''

60 function: 向数据库文件中的表插入多条数据61 '''

62 #连接数据库

63 connect =sqlite3.connect(self.dbName)64 #插入多条数据

65 connect.executemany("INSERT INTO {} VALUES(?,?,?,?,?,?,?,?,?,?,?,?,?)".format(self.tableName), self.data)66 #for i in range(len(self.data)):

67 #connect.execute("INSERT INTO university VALUES(?,?,?,?,?,?,?,?,?,?,?,?,?)", data[i])

68 #提交事务

69 connect.commit()70 #断开连接

71 connect.close()72

73 defgetAllData(self):74 '''

75 function: 得到数据库文件中的所有数据76 '''

77 #连接数据库

78 connect =sqlite3.connect(self.dbName)79 #创建游标对象

80 cursor =connect.cursor()81 #读取数据

82 cursor.execute("SELECT * FROM {}".format(self.tableName))83 dataList =cursor.fetchall()84 #断开连接

85 connect.close()86 returndataList87

88 def searchData(self, conditions, IfPrint=True):89 '''

90 function: 查找特定的数据91 '''

92 #连接数据库

93 connect =sqlite3.connect(self.dbName)94 #创建游标

95 cursor =connect.cursor()96 #查找数据

97 cursor.execute("SELECT * FROM {} WHERE {}".format(self.tableName, conditions))98 data =cursor.fetchall()99 #关闭游标

100 cursor.close()101 #断开数据库连接

102 connect.close()103 ifIfPrint:104 self.printData(data)105 returndata106

107 defdeleteData(self, conditions):108 '''

109 function: 删除数据库中的数据110 '''

111 #连接数据库

112 connect =sqlite3.connect(self.dbName)113 #插入多条数据

114 connect.execute("DELETE FROM {} WHERE {}".format(self.tableName, conditions))115 #提交事务

116 connect.commit()117 #断开连接

118 connect.close()119

120 defprintData(self, data):121 print("{1:{0}^3}{2:{0}<11}{3:{0}<4}{4:{0}<4}{5:{0}<5}{6:{0}<5}{7:{0}^5}{8:{0}^5}{9:{0}^5}{10:{0}^5}{11:{0}^5}{12:{0}^6}{13:{0}^5}".format(chr(12288), *self.COLUMNS))122 for i inrange(len(data)):123 print("{1:{0}<4.0f}{2:{0}<10}{3:{0}<5}{4:{0}<6}{5:{0}<7}{6:{0}<8}{7:{0}<7.0f}{8:{0}<8}{9:{0}<7.0f}{10:{0}<6.0f}{11:{0}<9.0f}{12:{0}<6.0f}{13:{0}<6.0f}".format(chr(12288), *data[i]))124

125 defrun(self):126 try:127 #创建数据库文件

128 self.creatTable()129 print(">>> 数据库创建成功!")130 #保存数据到数据库

131 self.insertDataS()132 print(">>> 表创建、数据插入成功!")133 except:134 print(">>> 数据库已创建!")135 #读取所有数据

136 ifself.Read_All:137 self.printData(self.getAllData())138

139 defget_data(fileName):140 '''

141 function: 读取获得大学排名的数据 并 将结果返回142 '''

143 data =[]144 #打开文件

145 f = open(fileName, 'r', encoding='utf-8')146 #按行读取文件

147 for line inf.readlines():148 #替换掉其中的换行符和百分号 替换百分号是为了方便之后的排序和运算

149 line = line.replace('\n', '')150 line = line.replace('%','')151 #将字符串按照 ',' 分割为列表

152 line = line.split(',')153

154 for i inrange(len(line)):155 #使用 异常处理 避开 出现中文无法转换 的错误

156 try:157 #将空值填充为 0

158 if line[i] == '':159 line[i] = '0'

160 #将数字转换为数值

161 line[i] =eval(line[i])162 except:163 continue

164 data.append(tuple(line))165 #EN_columns、CH_columns 分别为 用于数据库创建、数据的格式化输出

166 EN_columns = "Rank real, University text, Province text, Grade real, SourseQuality real, TrainingResult real, ResearchScale real, \167 ReserchQuality real, TopResult real, TopTalent real, TechnologyService real, Cooperation real, TransformationResults real"

168 CH_columns = ["排名", "学校名称", "省市", "总分", "生涯质量", "培养结果(%)", "科研规模", "科研质量", "顶尖成果", "顶尖人才", "科技服务", "产学研合作", "成果转化"]169 return data[1:], EN_columns, CH_columns170

171 if __name__ == "__main__":172 #=================== 设置和得到基本数据 ===================

173 fileName = "D:\\University_Rank.csv"

174 data, EN_columns, CH_columns =get_data(fileName)175 dbName = "university.db"

176 tableName = "university"

177

178 #================= 创建一个SQL_method对象 ==================

179 SQL =SQL_method(dbName, tableName, data, EN_columns, CH_columns, False)180

181 #=================== 创建数据库并保存数据 ===================

182 SQL.run()183

184 #=================== 在数据库中查找数据项 ===================

185 #查找记录并输出结果

186 print(">>> 查找数据项(University = '广东工业大学') :")187 SQL.searchData("University = '广东工业大学'", True)188

189 #================= 在数据库中筛选数据项并排序 ==================

190 #将选取广东省的数据 并 对科研规模大小排序

191 print("\n>>> 筛选数据项并按照科研规模排序(Province = '广东省') :")192 SQL.searchData("Province = '广东省' ORDER BY ResearchScale", True)193

194 #=============== 对数据库中的数据进行重新排序操作 ================

195 #定义权值

196 Weight = [0.3, 0.15, 0.1, 0.1, 0.1, 0.1, 0.05, 0.05, 0.05]197 value, sum =[], 0198 #获取 Province = '广东省' 的所有数据

199 sample = SQL.searchData("Province = '广东省'", False)200 #按照权值求出各个大学的总得分

201 for i inrange(len(sample)):202 for j inrange(len(Weight)):203 sum += sample[i][4+j] *Weight[j]204 value.append(sum)205 sum =0206 #将结果通过 pandas 的 DataFrame 方法组成一个二维序列

207 university = [university[1] for university insample]208 uv, tmp =[], []209 for i inrange(len(university)):210 tmp.append(university[i])211 tmp.append(value[i])212 uv.append(tmp)213 tmp =[]214 df = DataFrame(uv, columns=list(("大学", "总分")))215 df = df.sort_values('总分')216 df.index = [i for i in range(1, len(uv)+1)]217 #输出结果

218 print("\n>>> 筛选【广东省】的大学并通过权值运算后重排名的结果:\n", df)219

220 #===================== 在数据库中删除数据项 =====================

221 SQL.deleteData("Province = '北京市'")222 SQL.deleteData("Province = '广东省'")223 SQL.deleteData("Province = '山东省'")224 SQL.deleteData("Province = '山西省'")225 SQL.deleteData("Province = '江西省'")226 SQL.deleteData("Province = '河南省'")227 print("\n>>> 数据删除成功!")228 SQL.printData(SQL.getAllData())229

230 #====================== 在数据库中删除表 ========================

231 SQL.destroyTable()232 print(">>> 表删除成功!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值