python制作三维散点图

article/2025/11/5 6:02:38

最近需要做个文献分类汇总,老师要求要用三维散点图来画。中间还是有一些困难的,稍微记录下。

1.用python读取excel整理的数据,使用的是openpyxl库
方法比较简单,考虑到后续的标签问题,我直接把数据全部用数字代替,后续再用中文替换三维散点图的坐标轴数字。
具体代码如下:

import openpyxlworkbook = openpyxl.load_workbook("Data/2.xlsx")
sheet = workbook["Sheet1"]
# rows 按照行获取表单中所有的格子,每一行的数据放到一个元祖中
res = list(sheet.rows)# 获取excel表格中的第一行的数据,作为字典的key==》生成一个list列表
title = [i.value for i in res[0]]# 作为每个字典的容器
cases = []
# 遍历234行
for item in res[1:]:# 获取每行的数据dataline = [i.value for i in item]# 把遍历的每行数据与第一行title数据打包成字典dicline = dict(zip(title, dataline))cases.append(dicline)years=[]
for i in cases:i =int(i['年份'])years.append(i)
'''
编号如下:
1 谷类作物:小麦、玉米、水稻   2 5 8               
2 豆类作物:豌豆、豆角、蚕豆、大豆     1 4 9 11    
3 蔬菜作物:青菜、菠菜、油菜、甘蓝、甜菜   7 10 13 15 
4 纤维作物:棉花   3
5 果类作物:西瓜、猕猴桃  14 16
6 饮料作物:茶叶  6
'''
envs=[]
for i in cases:envs.append(i['实验环境'])
methods = []
'''
编号如下:
地面-数码相机:1
地面-光学相机:2
无人机-光学相机:3
无人机-数码相机:4
'''
for i in cases:# print(i)methods.append(i['采集方法'])data = []
for i in range(len(years)):for j in range(len(envs)):if i==j:for k in range(len(methods)):if j==k:t=[years[i],envs[i],methods[i]]data.append(t)
print(data)

excel文件如下:
在这里插入图片描述
2.三维散点图的处理是用pyplot
三维散点图的坐标刻度要替换成中文字符
关于x,y轴,非常简单,使用ticks()方法就可以。对于z轴,比较复杂,网上搜了很多,最后采用的是set_zticklabels()。因为数据分类的原因,散点图有重叠的问题,有两种方法可以解决这个问题,透明度和抖动。透明度可以做区分,但是会显得数据量很少,所以采用的是抖动,产生抖动的点会发生透明度变化。具体代码如下:

import matplotlib.ticker as ticker
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
from test2 import data
import numpy as np
import seaborn# 引入数据
data1 = np.array(data)
x = data1[:,0]
y = data1[:,1]
z = data1[:,2]# 绘制散点图
fig =plt.figure()
ax = Axes3D(fig)
seaborn.regplot(data = data1,x=x ,y=y,fit_reg = False,x_jitter = 0.4, y_jitter = 0.4,scatter_kws = {'alpha' : 2/3},color='r')
ax.scatter(x,y,z,c='r', label='122')# 设置三个坐标轴
ax.set(xlabel='年份',ylabel='对象',zlabel='方法')
ax.set_zticklabels(['','','地面-数码相机','','地面-光学相机','','无人机-光学相机','','无人机-数码相机'])
# 设置坐标轴刻度大小
ax.tick_params(labelsize=6,length=5,grid_alpha=0)
# 不显示刻度线
ax.xaxis.set_major_locator(ticker.NullLocator())
'''
新的分类:
1 谷类作物:小麦、玉米、水稻   2 5 8               
2 豆类作物:豌豆、豆角、蚕豆、大豆     1 4 9 11    
3 蔬菜作物:青菜、菠菜、油菜、甘蓝、甜菜   7 10 13 15 
4 纤维作物:棉花   3
5 果类作物:西瓜、猕猴桃  14 16
6 饮料作物:茶叶  6
'''
plt.xlim(0,16)
plt.ylim(0,6)
plt.xticks(np.arange(0,16,4),['2022-2019','2018-2015','2014-2011','2010-2007'],rotation='horizontal')
plt.yticks(np.arange(0,6,1),['谷类作物','豆类作物','蔬菜作物','纤维作物','果类作物','饮料作物'],rotation='vertical')# 中文显示
plt.rcParams["font.sans-serif"]=["SimHei"] #设置中文字体
plt.rcParams["axes.unicode_minus"]=False #该语句解决图像中的“-”负号的乱码问题
# 保存图片
plt.savefig("6.png",dpi=1200,bbox_inches ='tight')
plt.show()

最后的效果图如下:
在这里插入图片描述

祝好


http://chatgpt.dhexx.cn/article/mS4v2oUO.shtml

相关文章

Python matplotlib绘制散点图

Python matplotlib绘制散点图 上篇文章介绍了使用matplotlib绘制折线图,参考:https://blog.csdn.net/weixin_43790276/article/details/109191533,本篇文章继续介绍使用matplotlib绘制散点图。 一、matplotlib绘制散点图 # codingutf-8 im…

Python绘图-散点图(scatter)

绘制散点图的语法格式如下: ​ plt.scatter(x, y, sNone, cNone, markerNone, cmapNone, normNone, vminNone, vmaxNone, alphaNone, linewidthsNone, *, edgecolorsNone, plotnonfiniteFalse, dataNone, **kwargs)​ x,y:表示数据点的位置。 s:表示数据点的大小…

[Python] 散点图(二维散点图、三维散点图、散点图矩阵)

目录 1 两主特征:二维散点图 1.1 二维散点图 1.2 二维分类散点图 1.3 气泡图 2 三主特征:三维散点图 2.1 三维散点图 2.2 三维分类散点图 3 多主特征:二维散点图矩阵 3.1 二维散点图矩阵 3.2 二维分类散点图矩阵 以python自带数据鸢…

Python数据可视化之散点图(基础篇---图文并茂详细版!!!)

Python数据可视化之散点图 介绍准备工作所需的库虚拟环境 简单散点图总结 两种不同颜色和图例的散点图总结 介绍 •数据可视化的应用十分广泛,几乎可以应用于自然科学、工程技术、金融、通信和商业等各种领域。下面我们基于Python,介绍一下第一个常用知识点—散点图…

C语言求和问题

问题描述:编写一个程序,求s1(12)…(123…n)

c语言求和

或者可以这样写 注意!下面的写法是错的,数字是随机的,因为只声明没赋值

c语言数列求和中有乘法,C语言数列求和(使用while循环)

这是一个C语言 while 循环的示例,已知有下面的数列: 现在任意给出一个整数 k(1≤k≤15),要求计算出一个最小的 n,使得 Sn>k。 问题分析 输入:一个整数k(1≤k≤15)。 输出:最小的n。 本题算法非常简单&am…

用C语言计算矩阵求和

样例描述&#xff1a; 代码如下&#xff1a; #include<stdio.h> int main() {int N,n,a[51][51],r,c,i,num1,num2,num3,num4;scanf("%d",&N);nN*N;for(r1;r<N;r){for(c1;c<N;c)scanf("%d",&a[r][c]);}for(r1;r<N;r){num10;for(c1;…

c语言初学者如何编写一个相加求和程序

欢迎来到南方有乔木的博客&#xff01;&#xff01;&#xff01; 博主主页&#xff1a;点击点击&#xff01;戳一戳&#xff01;&#xff01; 博主QQ:1636758318 博主简介&#xff1a; 一名在校大学生&#xff0c;正在努力学习Java语言编程。穷且意坚&#xff0c;不坠青云之志&…

C语言斐波那契数列求和两种方法

递归调用函数&#xff1a; #define _CRT_SECURE_NO_WARNINGS int fun(int n); #include<stdio.h> int main() {//斐波那契数列递归求法int a[100] { 0,1,1 };int n, i, sum 0;scanf("%d", &n);for (i 1; i <n; i){sum fun(i);}printf("%d\n&q…

用c语言写一个求和的程序,C语言实现两数求和

能够使一个正确的C语言程序执行的必要顺序&#xff1a;上机输入与编辑源程序(.c)-->对源程序进行编译(.obj)&#xff0c;得到目标函数-->将目标程序 与库函数链接&#xff0c;得到可执行的目标程序(.exe)-->运行可执行的目标程序。今天是一个加法求和的功能的程序&…

c语言 中的求和函数,0基础理解C语言调用汇编实现求和函数

0基础踏入嵌入式开发的第一坑!用无敌简简单单的C程序调用汇编程序实现整数相加,这辈子都有阴影了,这大概是一条一条指令谷歌百度搜出来的结果,学习从来没这么卑微过,唔QAQ 工程大概长这样: add10.s ;routine for the addition of many integers. ;R0 is the counter of t…

C语言整数求和

带注释 #include <stdio.h> //头文件 int main(void) //主函数无参数&#xff0c;返回的值是整数 {long num; //定义了一个长整型变量numlong sum0L; //定义了一个长整型变量sum&#xff0c;把sum初始化为long类型的0printf("Please input an integer to s…

C语言用函数写两数之和

#include<stdio.h> void main() { int a,b,sum; scanf("%d,%d",&a,&b); sumab; printf("%d%d%d",a,b,sum); } 主函数接收和输出&#xff0c;被调函数求和 #include<stdio.h> int add(int a,int b); void main() { int a…

c语言整数各位数字求和

编写函数int sum(int x)&#xff0c;求整数x的各位数字之和。编写一个程序&#xff0c;调用sum函数计算任一输入的整数的各位数字之和。 【输入形式】 控制台输入一个整数。 【输出形式】 输出一个整数&#xff0c;是根据该输入整数计算各位数字之笔。 #include<stdio.h&…

C语言及程序设计初步——计算求和

C语言及程序设计初步——计算求和 一、初识C语言&#xff0c;并用简单的printf()与scanf()简单书写求和程序。 &#xff08;1&#xff09;、代码如下&#xff1a; /* *copyright(c)2018,CSDN学院 *All rights reserved. *文件名称&#xff1a;求和 *作 者&#xff1a;刘杰…

C语言实现根据用户输入的整数求和(两种方法)

根据用户输入的整数求和。 程序分析&#xff1a; while (number 1) 运算符是C的相等运算符&#xff0c;该表达式判断number是否等于1。 注意&#xff1a;不要把number1与number1混淆&#xff0c;后者是把1赋给status。 根据测试条件number1&#xff0c;只要number等于1&a…

C语言——求和一

C语言——求和 来自ACM 我的代码&#xff1a; #include<stdio.h> int main ( void ) { int n;//加数的个数 scanf("%d",&n); while(n!0)//以0结束 {int num;int sum 0;while(n--){scanf("%d",&num);sum num;}printf("%d\n",su…

python画折线图坐标带时间

一、普通不带时间 for i in dataf["y"][-240:]:people.append(i) plt.plot(people) plt.show() 二、带时间 data pd.Series(dataf[y].values, indexdataf[time])[-240:] rf data.values.tolist() y_we pd.DataFrame(rf, columns["day"], indexdata.in…

python画散点图分布-python画图汇总(持续更新)

折线图 plt.figure(figsize=(40, 40)) # 确定图像画布的大小 plt.subplot(211) # 将画布分为两行一列 plt.xlabel(Number of sample, fontsize=40) # x轴的label plt.ylabel(Characteristics of the amplitude, fontsize=40) # y轴的label 备注(plot所有的原件都可以加font…