第十章用Python获取sqlite、MySQL、Excel、csv、json中的数据

news2024/10/6 10:38:53

这里写目录标题

    • 项目背景
    • 获取sqlite3中的数据
      • sqlite3库获取sqlite数据
      • pandas库获取sqlite数据
    • 获取MySQL中的数据
      • pymsql库获取MySQL数据
      • pandas库获取mysql数据
    • 获取Excel中的数据
      • xlrd库获取Excel数据
      • pandas库获取Excel数据
    • 获取csv中的数据
      • csv库读取csv数据
      • pandas读取csv数据
    • 获取json中的数据
      • json库读取json数据
      • pandas读取json数据
    • 总结

本文可以学习到以下内容:

  1. 用Python、pandas获取sqlite3中的数据
  2. 用Python、pandas获取MySQL中的数据
  3. 用Python、pandas获取Excel、csv、json中的数据

关注微信公众号《帅帅的Python》,后台回复《数据分析》获取数据及源码

在这里插入图片描述

项目背景

小凡所在的数据部门需要经常和各种数据打交道,包括数据库、Excel、csv、json。面对各种各样的数据,小凡总结了一套数据读取的方法。

获取sqlite3中的数据

  • sqlite3是一个很轻量级C语言库,可以提供一种基于磁盘的数据库。在浏览器、手机、电子设备中广泛使用。
  • 我们可以用SQL语句查询数据,还可以用Python操作sqlite3数据库对数据进行查询。
  • 更多详细操作,官网地址:https://docs.python.org/zh-cn/3.9/library/sqlite3.html

sqlite3库获取sqlite数据

import sqlite3
# 创建一个连接对象,连接上上级目录下的 data.db 数据库
conn = sqlite3.connect("../data.db")
# 创建一个游标对象,操作数据库中的数据
c = conn.cursor()
# 执行 SQL 语句查询数据
sql = "select * FROM salesSummary limit 5;"
result = c.execute(sql)
# 查看数据
for r in result:
    print(r)
# 数据操作完成后,需要关闭数据库的连接
conn.close()

将此操作封装为函数:

def get_sqlite3_data(sql,db_path="../data.db"):
    conn = sqlite3.connect(db_path)
    c = conn.cursor()
    # 将数据保存到列表中
    result = [r for r in c.execute(sql)]
    conn.close()
    return result

调用函数:

sql = "select * FROM salesSummary limit 5;"
result = get_sqlite3_data(sql)
print(result)

pandas库获取sqlite数据

  • pandas读取sqlite3数据需要用到sqlalchemy库
  • sqlalchemy官网地址:https://www.osgeo.cn/sqlalchemy/
  • pandas的read_sql方法通过sql语言获取数据
import os
import pandas as pd
import numpy as np
from sqlalchemy import create_engine

# 数据库地址:数据库放在上一级目录下
db_path = os.path.join(os.path.dirname(os.getcwd()),"data.db")
engine_path = "sqlite:///"+db_path

# 获取数据函数,根据输入的SQL语句返回 DataFrame 类型数据
def link_sqlite(sql):
    engine = create_engine(engine_path)
    df = pd.read_sql(sql,con=engine)
    return df

sql = "select * from salesSummary"
df = link_sqlite(sql)

# 查看数据前5条数据
df.head()

获取MySQL中的数据

  • MySQL是个人和中小型企业常用的关系型数据库
  • 体积小、速度快、成本低,开放源码
  • python读取没有MySQL需要安装 pymysql 第三方库
pip install pymysql

pymsql库获取MySQL数据

import pymysql

host = "127.0.0.1"
port=3306
user="user"
password="password"
database="database"

conn = pymysql.connect(
    host=host,
    port=port,
    user=user,
    password=password,
    database=database
)

cursor = conn.cursor()

sql = "select * from country limit 5;"
cursor.execute(sql)

cursor.fetchone()

conn.close()

将此操作封装为函数使用:

import pymysql

host = "127.0.0.1"
port=3306
user="user"
password="password"
database="database"


def get_mysql_data(sql):
    conn = pymysql.connect(host=host,port=port,user=user,password=password,database=database)
    cursor = conn.cursor()
    cursor.execute(sql)
    result = [r for r in cursor.fetchall()]
    conn.close()
    return result

pandas库获取mysql数据

  • 官方文档:https://docs.sqlalchemy.org/en/20/intro.html
  • 需要先安装 SQLAlchemy和pymysql第三方库
from sqlalchemy import create_engine
# 当密码中有特殊符合时:@!@#$%^&*(),需要处理一下
from urllib.parse import quote_plus as urlquote

host = "127.0.0.1"
port=3306
user="user"
password="password"
database="database"
url = f"mysql+pymysql://{user}:{urlquote(password)}@{host}:{port}/{database}"

engine = create_engine(url=url)

sql = "select * from country limit 5;"
df = pd.read_sql(sql,con=engine)

获取Excel中的数据

  • Excel是一款电子表格软件,出色的计算功能和图表工具
  • Python获取Excel数据需要安装 xlrd 库
  • 文档地址:https://xlrd.readthedocs.io/en/latest/
pip install xlrd

xlrd库获取Excel数据

import xlrd

# 打开指定的Excel文件
workbook = xlrd.open_workbook("../数据源/省市区adcode与经纬度映射表.xlsx")

# Excel文件中的工作薄数量
sheet_num = workbook.nsheets
# Excel 文件中工作薄名字
sheet_name = workbook.sheet_names()

# 打开第一个工作簿
sheet = workbook.sheet_by_index(0)
# 工作薄名字
sh_name = sheet.name
# 工作簿行数
sh_rows = sheet.nrows
# 工作簿列数
sh_cols = sheet.nclos

# 获取指定单元格的数据
cell = sheet.cell_value(rowx=29,colx=3)
# 获取一行数据
row_value = sheet.row(0)
# 获取一列数据
col_value = sheet.col(0)

print(sheet_name,sh_name,sh_rows,sh_cols,cell,row_value)
print(col_value)

pandas库获取Excel数据

  • pandas使用read_excel方法获取Excel数据
import numpy as np
import pandas as pd

df= pd.read_excel("../数据源/省市区adcode与经纬度映射表.xlsx")

df.head()

获取csv中的数据

  • csv以纯文本形式存储表格数据,已字符分割不同值
  • CSV是一种通用的、相对简单的文件格式,被用户、商业和科学广泛应用
  • Python内置的csv模块可以读取csv数据

csv库读取csv数据

import csv

with open("../数据源/sale.csv",encoding="gbk") as f:
    f_csv = csv.reader(f)
    header = next(f_csv)
    print(header)
    for r in f_csv:
        print(r)

pandas读取csv数据

  • pandas的read_csv方法获取数据
import numpy as np
import pandas as pd

df= pd.read_csv("../数据源/earphone_sentiment.csv")

获取json中的数据

  • json是一种轻量级的数据交换格式
  • 简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言
  • Python内置的json模块可以读取csv数据

json库读取json数据

import json

with open("../数据源/商品销售额.json") as f:
    json_data = json.load(f)
    print(json_data)

pandas读取json数据

  • pandas中的read_json方法获取数据
import numpy as np
import pandas as pd

df = pd.read_json("../数据源/商品销售额.json")

总结

数据获取是数据分析的基础,小凡总结的只是常用代码中的一小部分,数据分析的道路任重道远…

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/86636.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Docker02(数据卷)

目录 一、宿主机与容器之间的文件拷贝 二、数据卷 三、数据卷容器 四、Dockerfile Dockerfile简介 自定义centos,具备vim及ifconfig作用 自定义tomcat8 一、宿主机与容器之间的文件拷贝 在生产环境中使用 Docker ,往往需要对数据进行持久化&#…

Spring Cloud微服务治理框架深度解析

在学习一个技术之前,首先我们要了解它是做什么的,我们为什么要用它。不然看再多资料都理解不了,因此我们先来讲解下Spring Cloud Spring Cloud是一套微服务治理框架,几乎考虑到了微服务治理的方方面面。那么接下来具体说下 Spring…

WebRTC客户端主要流程分析

1.通信过程 因为WebRTC规范里没有包含信令协议,所以像OWT、mediasoup等支持WebRTC的开源项目,其通信两端建立连接的过程中的信令逻辑各不相同。但是,总体上来说,其通信过程必然会包括以下过程。 发起端创建本地的PeerConnection&…

基于微信小程序的校友录系统-计算机毕业设计

项目介绍 本系统采用微信开发者开发、结合后台java语言以及Mysql数据库等技术。系统主要分为管理员和用户、校友三部分,管理员服务端:首页、个人中心、用户管理、校友管理、校友风采管理、校友视频管理、视频分类管理、班级信息管理、留言板管理、论坛交…

虹科方案|适用于VMware vSphere®环境的Mac Pro®和微型服务器存储连接

一、前言 Thunderbolt支持ATTO的VMWare ESXi和ThunderLink产品线,使我们能够创建基于Mac的vSphere设置,从而能够为我们的macOS服务器提供虚拟化服务。将虚拟硬件、快照和Veeam备份与macOS服务器的简单性相结合,将改变SMB市场的游戏规则。 二…

3y开发都不的不写单元测试,然后被被批了

他是3y,一年CRUD经验用十年的markdown程序员👨🏻‍💻常年被誉为职业八股文选手 最近在看单元测试的东西,想跟大家聊聊我的感受。单元测试这块说实在的,我并不太熟悉,我几乎不写单元测试&#x…

基于Sovit3D可视化开发的智慧港口数字孪生系统

港口作为经济的晴雨表,是现代经济的血液,是促进贸易和地区发展的重要基础设施。全球贸易中约90%的贸易由海运业承载,港口是其中重要一环。 建设背景 作为“21世纪海上丝绸之路”的重要节点,港口在“一带一路”建设中有着举足轻重…

nginx下载与安装

文章目录一.下载二.安装1.将压缩包上传到我们的服务器 /opt 目录下2.安装编译文件需要的c3.解压压缩包(首先需要进入 /opt 目录下 即压缩包文件所在目录)4.将解压后的文件夹剪切到指定目录 nginx ,这里我们放在了 /usr/local 目录下5.进入nginx文件目录6…

CentOS 7.9升级内核(kernel-5.4.218)

记录:362 场景:在CentOS 7.9操作系统上,使用ELRepo镜像仓库中kernel包,升级Linux 3.10.0-1160.el7.x86_64内核到kernel-5.4.218。ELRepo项目专注于Linux和CentOS操作系统的硬件相关的软件包。 版本: 操作系统&#…

自动化测试框架如果都总结成这样,人人都能学好

1、自动化测试框架设计的核心,可以概括为解决以下这些问题: 1)测试数据要怎么准备,如何在框架中实现,是否可复用。 2)测试用例的批量导入。 3)用例之间是否存在逻辑关系,相互之间是否有影响,在框架中该如何…

nginx平滑升级(2022.12.13)

相关视频教程: https://www.bilibili.com/video/BV1BK411W7hn 相关文章: https://blog.csdn.net/u012885136/article/details/122054931 nginx平滑升级 1、旧版本的nginx ps -ef | grep nginx2、解压新版本nginx ,进行编译安装 tar -xvf nginx-1.20.…

Spring使用指南 ~ 5、Spring AOP 使用简介

Spring AOP 使用简介 一、通知(Advice) 公共使用类 Agent.java package com.luo.spring.guides.aop.simple.domain;public class Agent {public void speak() {System.out.println("Bond");} }1、前置通知 package com.luo.spring.guides.…

算法拾遗二十二之Dijstra算法优化+认识一些经典的递归过程

Dijstra算法优化 public static class NodeRecord {public Node node;public int distance;public NodeRecord(Node node, int distance) {this.node node;this.distance distance;}}public static class NodeHeap {private Node[] nodes; // 实际的堆结构// key 某一个node&…

VS2019封装C++接口至可执行动态链接库.dll

VS2019封装C接口至可执行动态链接库.dll 本文主要总结如何对已实现的C函数、类进行封装,以便在其他平台或者语言上进行便捷使用或者二次开发! 重点参考: 1.https://blog.csdn.net/hai_fellow_Z/article/details/117290517 2.https://blog.csd…

打工人的发展困境

近期在公司内部QE社区举办了一场研讨会,主题是《QA角色职业发展机遇讨论》。收集到以下观点,觉得挺有意思,又不局限于特定角色,于是用XX代替QA。 无论是在公司内部还是外部,XX都是单独作战居多,从他人身上…

都在说00后是躺平的一代,公司刚来的00后却把我卷哭了

上个月公司来了许多新面孔,其中居然有一个是00年的,虽然也给公司带来了一些新的血液,但也让我意识到,自己年级确实不小了。这小老弟是去年毕业的,在某软件公司干了半年,现在跳槽到我们公司起薪18K&#xff…

通过数据分析提升客流量和销售额

只有把每一位来光临的顾客都当作最后一位顾客,我们才可能真正实现营销和服务管理的精细化,正如只有把自己的每一天都当作生命的最后一天来对待的人才可能真正珍惜时间和生命一样。 如何提高门店的销售额可以说是大部分店长都十分困惑的问题,…

12月13日 OpenCV 实战基础学习笔记——Harris、SIFT

文章目录前言一、Harris 角点检测1、公式推导2、找到 E(u,v)E(u, v)E(u,v) 的最大值二、SIFT1、关键点定位 keypoint localisation2、特征描述 feature description前言 本文为12月13日 OpenCV 实战基础学习笔记,分为两个章节: Harri 角点检测&#xf…

docker安装Gitlab、修改密码、创建组、创建项目、创建用户、Git拉取代码

安装 建议内存大于2G 开放防火墙端口80和配置映射文件夹 firewall-cmd --zonepublic --add-port80/tcp --permanent firewall-cmd --reload mkdir -p /docker_data/gitlab/{data,logs,config}启动Gitlab容器(启动容器之前确保22,80,443端口没…

图解外包验收流程V2.0及详细说明实例

详细说明 01、【开发计划内容】-标准模板{文档} 1.包含二级模块开发计划,标注里程碑验收节点; 2.包含架构设计、数据库设计输出时间; 3.包含接口开发计划及其接口明细; 4.所有节点分配到具体的人和具体的开始结束时间&#xff1…