锋盈数科-知识库 Logo
首页
软件开发
计算机基础
Hello Halo
新手必读
关于本知识库
登录 →
锋盈数科-知识库 Logo
首页 软件开发 计算机基础 Hello Halo 新手必读 关于本知识库
登录
  1. 首页
  2. 软件开发
  3. Python读取Excel表格数据并画图保存(pandas读取、matplotlib画图)

Python读取Excel表格数据并画图保存(pandas读取、matplotlib画图)

0
  • 软件开发
  • 发布于 2024-08-19
  • 0 次阅读
黄健
黄健

天行健,君子以自强不息;地势坤,君子以厚德载物。


每个人都有惰性,但不断学习是好好生活的根本,共勉!


文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。


文章目录

  • 一、读取
    • 1. Excel表格文件
    • 2. 读取文件数据
    • 3. 执行程序打印结果
  • 二、画图
    • 1. 代码
    • 2. 画图结果
  • 三、保存图片
  • 四、完整代码


需先安装库:openpyxl、pandas和matplotlib库
资源下载:代码和excel文件的资源下载链接

一、读取

1. Excel表格文件

首先准备一个Excel文件,这里直接创建一个test01.xlsx文件
并在表中sheet页中填入数据,修改sheet页名称为car,如下

2. 读取文件数据

使用pandas工具读取test01.xlsx文件中名为car的sheet页数据

#引入pandas用于读取
import pandas as pd
#引入matplotlib用于画图
import matplotlib.pyplot as plt

#需要下载openpyxl,pandas

#使用pandas读取excel表,可指定sheet页的名字
df = pd.read_excel("./test01.xlsx",sheet_name="car")

#打印读取的模型
print("df: ",df)

print("="*100)

#打印表头字段
print("df.colums: ",df.columns)

3. 执行程序打印结果

打印如下,分别是读取的数据模型和表头字段列表

二、画图

将读取的数据模型通过matplotlib工具画图
需指定横轴和纵轴的坐标字段

1. 代码

在之前的代码后面继续编写以下代码

#以time_s为横轴、temp_c为纵轴画图
plt.plot(df["time_s"], df["temp_c"])
#展示画的图
plt.show()

2. 画图结果

执行程序后展示画图结果

三、保存图片

在画图后保存图片
在plt.plot()画图之后,plt.show()方法之前使用savefig()方法保存图片到本地

#以time_s为横轴、temp_c为纵轴画图
plt.plot(df["time_s"], df["temp_c"])

#保存图片到本地,保存在当前位置,以jpg格式存储
filename = "car"
plt.savefig(f"./{
     filename}.jpg")

#展示画的图
plt.show()

执行后生称图片到本地当前位置,名称为car.jpg

四、完整代码

#引入pandas用于读取
import pandas as pd
#引入matplotlib用于画图
import matplotlib.pyplot as plt

#需要下载openpyxl,pandas

#使用pandas读取excel表,可指定sheet页的名字
df = pd.read_excel("./test01.xlsx",sheet_name="car")

#打印读取的模型
print("df: ",df)

print("="*100)


#打印表头字段
print("df.colums: ",df.columns)

print("="*100)

#加一列
#将age字段值加100生成一个新的字段值age2
df["speed_km_h2"] = df["speed_km_h"]+100
#打印新的模型
print("df2:",df)

#以time_s为横轴、temp_c为纵轴画图
plt.plot(df["time_s"], df["temp_c"])

#保存图片到本地,保存在当前位置,以jpg格式存储
filename = "car"
plt.savefig(f"./{
     filename}.jpg")

#展示画的图
plt.show()



感谢阅读,祝君暴富!

原文链接: https://hanshan.blog.csdn.net//article/details/139278269

标签: #Python 23 #软件开发 1171
相关文章

万字:支付“核心系统”详解 2024-11-02 15:33

专栏作者:隐墨星辰 \| 主编:陈天宇宙 这篇文章也尝试化繁为简,探寻支付系统的本质,讲清楚在线支付系统最核心的一些概念和设计理念。 虽然支付行业已经过了风头最劲的时光,但跨境支付仍然在蓬勃发展,每年依然有很多新人进入这个行业,这篇文章尝试为这些刚入行的新人提供一点帮助。 文章只介绍一些支付行业十几

资深支付架构师视角:实战从问题定义到代码落地的完整套路 2024-11-02 15:33

前言 今天从一个实际案例入手,介绍站在架构师的角度,如何识别并定义问题,提炼需求,技术方案选型,再到详细设计,最后利用AI的能力协助写出核心的代码,验证与调优。 解决问题存在一定的模式,也可以称之为框架,总结出自己的思考和解题框架,以后再碰到同类型的问题就可以如庖丁解牛一样容易。 很多年前,我写代码

Spring 实现 3 种异步接口 2024-10-18 09:07

大家好,我是苏三~ 如何处理比较耗时的接口? 这题我熟,直接上异步接口,使用 Callable、WebAsyncTask 和 DeferredResult、CompletableFuture等均可实现。 但这些方法有局限性,处理结果仅返回单个值。在某些场景下,如果需要接口异步处理的同时,还持续不断地

重学SpringBoot3-集成Redis(五)之布隆过滤器 2024-10-08 11:24

更多SpringBoot3内容请关注我的专栏:《SpringBoot3》 期待您的点赞👍收藏⭐评论✍ 重学SpringBoot3-集成Redis(五)之布隆过滤器 1. 什么是布隆过滤器? * 基本概念 适用场景 2. 使用 Redis 实现布隆过滤器 * 项目依赖 Redis 配置

设计模式第16讲——迭代器模式(Iterator) 2024-10-08 11:24

一、什么是迭代器模式 迭代器模式是一种行为型设计模式,它提供了一种统一的方式来访问集合对象中的元素,而不是暴露集合内部的表示方式。简单地说,就是将遍历集合的责任封装到一个单独的对象中,我们可以按照特定的方式访问集合中的元素。 二、角色组成 抽象迭代器(Iterator):定义了遍历聚合对象所需的方法

vue2路由和vue3路由区别及原理 2024-10-08 11:24

一、Vue2 与 Vue3 路由的区别 1. 创建路由实例方式的不同 Vue 2 中,通过 Vue.use() 注册路由插件,并通过 new VueRouter() 来创建路由实例。 import Vue from 'vue';import VueRouter from 'vue-router';i

目录

IT 外包服务商

  • 意见投递
  • zyf6619

软件开发应用

主菜单

  • 首页
  • 软件开发
  • 计算机基础
  • Hello Halo
  • 新手必读
  • 关于本知识库
Copyright © 2024 your company All Rights Reserved. Powered by Halo.