创建pandas和sqlalchemy的j交互对象,方便于日常的数据库的增删改查(原创)
#导入第三方库sqlalchemy的数据库引擎
from sqlalchemy import create_engine
#导入科学计算库
import pandas as pd
#导入绘图库
import matplotlib.pyplot as plt if __name__ == "__main__":
#建立数据库引擎
engine = create_engine('mysql+pymysql://root:123456@localhost:3306/mymac') #建立一个基于pandas查询数据框架类的对象
sql = 'select id,name,age,gender from student'
df = pd.read_sql_query(sql,engine)
print("#建立一个基于pandas查询数据框架类的对象\n{}".format(df)) #select * from student order by age asc | desc
df0 = df.sort_values(['age','gender'],ascending=False)
print("#指定多字段排序,遵循最左原则,注意:这是矩阵数组操作,不是在数据库操作,需要重新赋值\n{}".format(df0)) df1 = df.sort_values(['age']).head(1)
print("#取年龄最小的学生,从头部取第一个\n{}".format(df1)) print('#所有字段的平均值\n{}'.format(df.mean()))
print('#矩阵 按列 求平均值\n{}'.format(df.mean(0)))
print('#矩阵 按行 求平均值\n{}'.format(df.mean(1))) #使用loc[]方法指定字段 .age指定操作数据字段
avg_age = df.loc[df['gender'] == 0].age.mean()
print("查整个班的女生的平均年龄: {}".format(avg_age)) view = df.loc[(df['age'] < avg_age) & (df['gender'] == 0)]
print("查小于全班平均年龄的女生\n{}".format(view))
print("全班平均年龄: {}".format(df.age.mean()))
print("全班年龄和: {}".format(df.age.sum()))
print("男生的年龄和: {}".format(df.loc[df['gender'] == 1].age.sum()))
print("全班最小年龄: {}".format(df.age.min()))
print(df.loc[(df['gender'] == 0) | (df['gender'] == 1)])
print("全班人数: {}".format(df.id.count()))
#排除
print(df.loc[(df['gender'] != 0) & (df['gender'] != 1)]) #修改
df.loc[3,'gender'] = 0
df.loc[3,'age'] = 18
print(df)
#取单值 nplist[2,3] nplist[2][3]
print(df.loc[3,'name'])
data = df.loc[ df['gend.er'] == 1, ['id','name']]
print("#查指定字段的数据\n{}".format(data)) """
导出excel文件
pandas的矩阵转成excel文件,需要安装一个Exel插件 pip install openpyxl
基于清华学校的镜像源安装 pip install -i https://pypi.tuna.tsinghua.edu.cn/simple openpyxl
将dataframe写入数据表 表名,数据引擎,索引是否入库
"""
df.to_sql('student_copy',engine,index=False)
#导出excel文件
df.to_excel('student.xlsx') # 一、利用dataframe内置方法,统计 李老师班身高超过1.80的所有男生
sql_0 = "select * from student as s inner join teacher as t on s.tid = t.id where t.id = 2 and s.gender = 1"
df_0 = pd.read_sql_query(sql_0,engine)
print(df_0)
view_0 = df_0.loc[df_0['hight'] > 1.80]
print(view_0) #二、利用dataframe内置方法,统计 王老师班身高不低于李老师班女生平均身高的所有女生
sql_1 = "select * from student as s inner join teacher as t on s.tid = t.id where s.gender = 0"
df_1 = pd.read_sql_query(sql_1,engine)
print("#1、查出所有老师的班级的女生\n{}".format(df_1)) view_1 = df_1.loc[(df_1['tid'] == 2)].hight.mean()
print("#2、李老师班的女生平均身高: {}".format(view_1)) view_2 = df_1.loc[(df_1['tid'] == 1) & (df_1['hight'] > view_1)]
print(view_2) """
要求:给student 表加入字段weight,利用matplotlib 画一个散点图,将全班的身高(x轴) 和 体重(y轴) 以散点图的形式展示出来
""" #建立一个基于pandas与sqlalchemy交互的对象
sql = 'select hight,weight from student'
df = pd.read_sql_query(sql,engine)
print(df) # #定义x轴数据
x = df['hight']
y = df['weight']
# 填充数据
#s 表示点的大小和粗细 c 表示颜色
plt.scatter(x,y,s=20,c='blue')
#设置标题
plt.title('身高(x轴)/体重(y轴)')
#绘制
plt.show()
创建pandas和sqlalchemy的j交互对象,方便于日常的数据库的增删改查(原创)的更多相关文章
- PHP程序中使用PDO对象实现对数据库的增删改查操作的示例代码
PHP程序中使用PDO对象实现对数据库的增删改查操作(PHP+smarty) dbconn.php <?php //------------------------使用PDO方式连接数据库文件- ...
- django之创建第8-1个项目-数据库之增删改查/数据库数据显示在html页面
1.为test.DB数据库预先创建下面数据 1 张三 16 2015-01-02 12 李四 17 2015-01-04 13 王五 14 ...
- magento中Model创建以及该Model对于数据库的增删改查
本文是按照magento英文文档照做与翻译的. Model层的实现是mvc框架的一个巨大的部分.它代表了你的应用的数据,或者说大多数应用没有数据是无用的.Magento的Model扮演着一个重要的角色 ...
- mogoose 创建数据库并增删改查
下载 npm i mongoose -s 连接数据库 const mongoose = require("mongoose"); mongoose.connect(dbURL); ...
- Java对象转JSON时如何动态的增删改查属性
1. 前言 日常开发中少不了JSON处理,少不了需要在JSON中添加额外字段或者删除特定字段的需求.今天我们就使用Jackson类库来实现这个功能. 2. JSON字符串增加额外字段 假如我们有这样结 ...
- sap 创建odata服务,通过http向数据库 进行增删改查
https://blog.csdn.net/stone0823/article/details/71057172 1:通过 事物码 se11 创建 数据库表 zemp.表 zemp中 含有empid ...
- 前后台交互实例二:前台通过django在数据库里面增删改查数据
url(r'^userinfo/', views.userinfo), url(r'^userdetail-(?P<nid>\d+)/', views.userdetail), url(r ...
- 用泛型创建SqlServerHelper类实现增删改查(一)
使用泛型,可以构建对数据库单表的基本增删改查. 首先有一数据库 Test_SqlServerHelper ,有2表 接下来创建项目,对数据库进行增删改查. 直接贴代码:(SqlServerHelper ...
- 啊啊啊啊啊啊啊今天就写,炒鸡简单 数据库Sqlite的创建,库的增删改查
啦啦啦啦啦啦啦 写这个不用多长时间,我直接写代码注释都是些语句,Sql语句和Api来操作数据库 ,语句的参数我会注释 SQLite数据库创建数据库需要使用的api:SQLiteOpenHelper必须 ...
随机推荐
- 关于:未能加载文件或程序集“ICSharpCode.SharpZipLib”或它的某一个依赖项异常的解决方案
问题: 今天项目迁移忽然又个ICSharpCode.SharpZipLib.dll 程序包丢失了,于是我在网上下载一个这样的包,结果程序运行就提示:未能加载文件或程序集“ICSharpCode.Sha ...
- PHP全栈学习笔记14
一.搭建PHP开发环境 Apahce服务器 Dreamwear创建站点 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona ...
- 第3章 简单的C程序设计——顺序程序设计
3.1 顺序程序设计举例 例:有人用温度计测量出用华氏法表示的温度(如64F),今要求把它转换为一摄氏法表示的温度(如17.8C) 解题思路:问题的关键在于找到两者的转换公式.根据物理学知识,公式为c ...
- mongo connections url string 的问题
摘要 driver 连接Mongo DB的url其实很简单,就是几个变量拼接成一个url,和关系型数据库没什么不同.但是因为mongo有单个instance和replicaSet不同的部署策略,还有m ...
- 配置中心框架IConfCenter
本篇和大家分享的是一个简易配置中心框架IConfCenter,框架是利用空余时间写的,主要以配置文件+redis存储方式作为数据同步驱动,目前支持的配置文件格式有 .properties 和 .con ...
- 死磕 java集合之TreeSet源码分析
问题 (1)TreeSet真的是使用TreeMap来存储元素的吗? (2)TreeSet是有序的吗? (3)TreeSet和LinkedHashSet有何不同? 简介 TreeSet底层是采用Tree ...
- SpringBoot实用小知识之Maven中dependencys和dependencymanagement区别
利用pom管理引用包时,如果是单项目的话就直接在dependencies引用了,若有一个大工程项目里面包含多个子模块,则为了所有项目模块包的版本统一和好管理,则需要用到dependencyManage ...
- 搞懂MySQL InnoDB事务ACID实现原理
前言 说到数据库事务,想到的就是要么都做修改,要么都不做.或者是ACID的概念.其实事务的本质就是锁和并发和重做日志的结合体.那么,这一篇主要讲一下InnoDB中的事务到底是如何实现ACID的. 原子 ...
- .net 笔试面试总结(2)
在.net 中类(class) 与结构(Struct)的异同. Class 可以被实例化,属于引用类型,是分配在内存的堆上的.类是引用传递的. Struct 属于值类型,是分配在内存的栈上的.结构体是 ...
- 升级WIN10 (9879)后IE无响应的解决办法
身为程序猿,当然有了新系统就要尝尝鲜,有WIN8时,哥是朋友圈第一个用的,有WIN8.1时哥也是第一个升级的. 现在WIN10来了,当然也得赶紧尝尝鲜.直接下载了 9879版的预览版本安装. 要说WI ...