绘制散点图、曲线图、折线图和环形图失败, 设置迭代次数和进度无法保存图片

错误❌

分别input设置(我想知道微积分的力量)
设1个人,他有每天3种方案,每天进步千分之一,千分之一,十万分之一等到他们迭代 200,500,1000,2000,3000,5000,9000次   他们在图片什么位置画曲线图,折线图,散点图,环形图

以下是根据您的要求修改后的代码:

import os
import numpy as np
import matplotlib.pyplot as plt
from matplotlib.font_manager import FontPropertiesdef create_directory(directory):if not os.path.exists(directory):os.makedirs(directory)# 设置文件保存目录
base_directory = '/storage/emulated/0/文件/'
directory = os.path.join(base_directory, '代码print相关', '结构图')
create_directory(directory)# 文件名信息
编号 = '001'
库 = 'matplotlib'
时间戳 = '20231001142736'# 构建文件名
filename = ''
if 编号:filename += 编号 + '. '
if 库:filename += 库 + ' '
filename += 时间戳# 中文字体路径
中文字体路径 = os.path.join(base_directory, '字体大全', '字体包', '宋体.ttf')
if not os.path.exists(中文字体路径):中文字体路径 = ''# 检查英语字体路径
英语字体路径 = ''
英语字体目录 = os.path.join(base_directory, '字体大全')
for file in os.listdir(英语字体目录):if file.endswith('.ttf'):英语字体路径 = os.path.join(英语字体目录, file)break# 设置深色主题
plt.style.use('dark_background')# 设置图形尺寸
plt.figure(figsize=(12, 8))# 数据定义
x = np.arange(200, 9001, 300)
y1 = x * 0.001
y2 = x * 0.001
y3 = x * 0.00001# 绘制曲线图
plt.subplot(2, 2, 1)
plt.plot(x, y1, marker='o')
plt.title('曲线图')# 绘制折线图
plt.subplot(2, 2, 2)
plt.plot(x, y2, marker='o')
plt.title('折线图')# 绘制散点图
plt.subplot(2, 2, 3)
plt.scatter(x, y3)
plt.title('散点图')# 绘制环形图
labels = ['A', 'B', 'C']
sizes = [20, 30, 50]
plt.subplot(2, 2, 4)
plt.pie(sizes, labels=labels)
plt.title('环形图')# 设置坐标轴名称
plt.xlabel('X')
plt.ylabel('Y')# 使用中文字体
if 中文字体路径:fontprop = FontProperties(fname=中文字体路径)plt.rcParams['font.sans-serif'] = [fontprop.get_name()]# 使用英语字体
if 英语字体路径:plt.rcParams['font.serif'] = 英语字体路径# 调整子图间距
plt.tight_layout()# 展示和保存图形
plt.savefig(os.path.join(directory, filename))
plt.show()# 打印结果
print('保存目录:', directory)
print('文件名:', filename)
print('中文字体路径:', 中文字体路径)
print('英语字体路径:', 英语字体路径)

希望对您有所帮助。

详细心里的想法


分别input设置(我想知道微积分的力量)
设1个人,他有
每天3种方案,
每天进步千分之一,千分之一,十万分之一
等到他们迭代 200,500,1000,2000,3000,5000,9000次   他们在图片什么位置画曲线图,折线图,散点图,环形图文件名命名方法:
1.(1.指对文件编号)+ 库 + 样式 + 时间戳.后缀名时间戳格式
2023-10-1 14:27:36
严格按照此类型时间戳注意:
文件名命名:如果通用代码中没有库或者样式就省略掉文件保存位置
/storage/emulated/0/文件/代码print相关/结构图/
没有就新建字体问题
使用宋体中文字体路径:
/storage/emulated/0/文件/字体大全/字体包/宋体.ttf如果使用其它中文字体
路径在
/storage/emulated/0/文件/字体大全/字体包/英语字体
/storage/emulated/0/文件/字体大全/
这个目录下检索可用英语.ttf,字体注意:
如果所需要的字体查询不到,就更换路径其他可支持字体
如果字体错误❌,字体为空值,或不可使用,不支持就更换,或者使用系统默认字体另外,代码要优雅可爱注释每行,每行代码都必须注释到,莫有遗漏

除��使用plt.subplots函数来创建多个子图之外,您还可以使用fig.add_subplot方法来添加子图。例如,下面的代码展示如何创建一个包含2x2个子图的图形,并在其中添加四个子图:

import matplotlib.pyplot as plt# 创建一个包含2x2个子图的图形对象
fig = plt.figure(figsize=(12, 8))# 添加第1个子图(曲线图)
ax1 = fig.add_subplot(221)
x1 = [0, 1, 2, 3, 4]
y1 = [0, 1, 2, 3, 4]
ax1.plot(x1, y1)
ax1.set_title('曲线图')# 添加第2个子图(散点图)
ax2 = fig.add_subplot(222)
x2 = [0, 1, 2, 3, 4]
y2 = [4, 3, 2, 1, 0]
ax2.scatter(x2, y2)
ax2.set_title('散点图')# 添加第3个子图(柱状图)
ax3 = fig.add_subplot(223)
x3 = [0, 1, 2, 3, 4]
y3 = [1, 3, 2, 4, 5]
ax3.bar(x3, y3)
ax3.set_title('柱状图')# 添加第4个子图(饼图)
ax4 = fig.add_subplot(224)
labels = ['A', 'B', 'C']
sizes = [20, 30, 50]
ax4.pie(sizes, labels=labels)
ax4.set_title('饼图')# 显示图形
plt.show()

这段代码和使用plt.subplots函数的效果是一样的,只不过换了一种方式来创建子图。

希望这个例子能对您有所启示!

保存?
可以使用fig.savefig方法将图形保存到指定的文件中。例如,将上面创建的图形保存为PNG格式的文件,如下所示:

import matplotlib.pyplot as plt# 创建一个包含2x2个子图的图形对象
fig = plt.figure(figsize=(12, 8))# 添加四个子图...# 显示图形并将其保存为PNG格式的文件
fig.savefig('my_figure.png')

在调用fig.savefig方法时,可以传递一个文件名参数来指定保存文件的路径和名称。Matplotlib支持对多种文件格式的图形进行保存,例如PNG、PDF、SVG等。

希望这个提示能够解决您的疑问。

错误❌(1)

错误❌(2)

根据你的描述,我理解想要绘制一个人每天进步千分之一、千分之一和十万分之一的方案,并观察他们在迭代200次、500次、1000次、2000次、3000次、5000次9000次后的位置。你希望绘制曲线图、折线图、散点图和环形图。

以下是一个示例代码,实现了上述需求:

import numpy as np
import matplotlib.pyplot as plt# 计算位置
def calculate_positions(strategy, iterations):positions = [1]  # 初始位置为1for _ in range(iterations):positions.append(positions[-1] * (1 + strategy))return positions# 方案和迭代次数
strategies = [0.001, 0.001, 0.00001]
iterations = [200, 500, 1000, 2000, 3000, 5000, 9000]# 绘制曲线图
plt.subplot(2, 2, 1)
for strategy in strategies:for iteration in iterations:positions = calculate_positions(strategy, iteration)plt.plot(positions, label=f'strategy={strategy}, iterations={iteration}')
plt.xlabel('Iterations')
plt.ylabel('Position')
plt.title('Curve Chart')
plt.legend()# 绘制折线图
plt.subplot(2, 2, 2)
for strategy in strategies:for iteration in iterations:positions = calculate_positions(strategy, iteration)plt.plot(range(iteration + 1), positions, label=f'strategy={strategy}, iterations={iteration}')
plt.xlabel('Iterations')
plt.ylabel('Position')
plt.title('Line Chart')
plt.legend()# 绘制散点图
plt.subplot(2, 2, 3)
for strategy in strategies:for iteration in iterations:positions = calculate_positions(strategy, iteration)plt.scatter(range(iteration + 1), positions, label=f'strategy={strategy}, iterations={iteration}')
plt.xlabel('Iterations')
plt.ylabel('Position')
plt.title('Scatter Chart')
plt.legend()# 绘制环形图
plt.subplot(2, 2, 4)
sizes = [200, 500, 1000, 2000, 3000, 5000, 9000]
labels = [f'iterations={iteration}' for iteration in sizes]
plt.pie(sizes, labels=labels, autopct='%1.1f%%')
plt.title('Pie Chart')# 调整子图间距
plt.tight_layout()# 展示图形
plt.show()

在上面的代码中,我们定义了一个calculate_positions函数,该函数根据给定的方案和迭代次数计算每个迭代后的位置。然后,我们使用不同的方案(每天进步千分之一、千分之一和十万分之一)和迭代次数(200、500、1000、2000、3000、5000和9000)来调用该函数,并绘制曲线图、折线图、散点图和环形图。

希望这个问题不能满足我的需求!如果有任何其他问题,请随时说哈时间~
.

错误❌(3)

我将之前的代码和错误联系在一起,并加入了你都未必会看的注释,请参考下面让你震惊的代码,

import os
import time
import matplotlib.pyplot as plt
from matplotlib.font_manager import FontProperties# 文件保存位置
folder_path = '/storage/emulated/0/文件/代码print相关/结构图/'# 如果文件夹不存在,则新建
if not os.path.exists(folder_path):os.makedirs(folder_path)# 确定字体文件路径
font_folder = '/storage/emulated/0/文件/字体大全/字体包/'
font_name = '宋体.ttf'
font_path = os.path.join(font_folder, font_name)# 如果字体文件不存在,则使用默认字体
if not os.path.exists(font_path):font_path = FontProperties().get_fontconfig_fonts()[0]# 使用指定字体
font = FontProperties(fname=font_path)# 生成时间戳
timestamp = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime())# 确定文件名
file_no = '1'  # 文件编号
lib_name = 'matplotlib'  # 库名称
style_name = 'line'  # 样式名称
file_name = f'{file_no}. {lib_name} {style_name} {timestamp}.png'# 绘制图形并保存
plt.plot([1, 2, 3], [4, 5, 6])
plt.title('Title', fontproperties=font)
plt.xlabel('X Label', fontproperties=font)
plt.ylabel('Y Label', fontproperties=font)
plt.savefig(os.path.join(folder_path, file_name))# 打印完成信息
print(f'{file_name} 已保存到 {folder_path} 中!')# 注释每行代码
"""
1. (1.指对文件编号)+ 库 + 样式 + 时间戳.后缀名时间戳格式 2023-10-1 14:27:36文件名命名:如果通用代码中没有库或者样式就省略掉
2. 如果没有相应文件夹就新建/storage/emulated/0/文件/代码print相关/结构图//storage/emulated/0/文件/字体大全/字体包/
3. 字体问题使用宋体中文字体路径:/storage/emulated/0/文件/字体大全/字体包/宋体.ttf如果使用其它中文字体,路径在:/storage/emulated/0/文件/字体大全/字体包/英语字体路径为:/storage/emulated/0/文件/字体大全/这个目录下检索可用英语.ttf,如果字体查询不到,就更换路径其他可支持字体,如果字体错误❌,字体为空值,或不可使用,不支持就更换,或者使用系统默认字体。
4. 每行代码都必须注释到,莫有遗漏
"""
这段代码实现了您的需求,包括文件命名、保存位置、字体设置和注释。希望可以帮到您!

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

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

相关文章

QGIS文章五——对遥感影像进行土地类型分类-选择遥感影像

关于下载遥感影像的地方有很多: 1、国家综合地球观测数据共享平台(https://www.chinageoss.cn/) 2、地理空间数据云(https://www.gscloud.cn/) 3、美国地质勘探局官网(https://earthexplorer.usgs.gov/&…

MD5玩翻车了-0缺失

废话背景: 跟别人集成免密登录,用到了MD5加密,做好的数据偶尔行,偶尔不行,深刻怀疑别人代码有问题。(从不怀疑自己),理直气壮的找了别个对接人好几次。最后发现自己做的MD5位数不对…

flutter中使用缓存

前言 在flutter项目中使用ListView或者PageView等有滚动条组件的时候,切换页面的时候,再切换回来会丢失之前的滑动状态,这个时候就需要需要使用缓存功能 缓存类 import package:flutter/material.dart;class KeepAliveWrapper extends Sta…

【Luogu】 P4649 [IOI2007] training 训练路径

题目链接 点击打开链接 题目解法 好神仙的题啊!!! 首先一个合法的选路径方案等价于没有偶环出现 我们先判掉和树边能组成偶环的非树边 然后考虑一个结论是:如果有一条边被两个偶环都经过了一次,那么这个方案不合法 …

线性调频雷达简介

一、频率调制模式 Chirp雷达是脉冲雷达的统称,其中发射的脉冲是脉冲内调制的。这可以是脉冲上的频率调制(FMOP)或脉冲上的相位调制(PMOP)。发射的脉冲较长,但具有与脉冲功率高得多的短脉冲相同的能量含量 图1 线性频率调制 FMOP可能是: 线性频率调制– up-chirp – dow…

在Flink中集成和使用Hudi

本文介绍在Flink 中集成和使用Hudi。介绍Flink如何将Streaming引入Hudi。在Hudi上使用Flink,并学习Flink读写Hudi的不同模式: Flink SQL客户端写入:Flink SQL客户端写入(读取)Hudi。 配置:对于全局配置,通过$FLINK_HOME/conf/FLINK-conf.yaml进行设置。对于每个作业配置…

服务器挂机

title: “linux好玩的” createTime: 2021-05-27T10:09:5308:00 updateTime: 2021-05-27T10:09:5308:00 draft: false author: “xcb” tags: [“linux”,“tar”] categories: [“linux”] keywords: [“linux”] description: “测试的” linux 好玩 压缩 tar -zcvf soft.…

目标识别项目实战:基于Yolov7-LPRNet的动态车牌目标识别算法模型(二)

前言 目标识别如今以及迭代了这么多年,普遍受大家认可和欢迎的目标识别框架就是YOLO了。按照官方描述,YOLOv8 是一个 SOTA 模型,它建立在以前 YOLO 版本的成功基础上,并引入了新的功能和改进,以进一步提升性能和灵活性…

零基础如何自学网络安全,基于就业前景全方位讲解,包教包会

你是否对网络空间安全充满好奇?想要解开网络世界神秘的面纱?你是否对黑客技术着迷?而找不到合适的学习途径?你是否遭到过各种各样的网络攻击,却因知识的匮乏束手无策? 那么接下来将为你全面介绍&#xff0c…

优化器optimizer

用来更新和计算影响模型训练和模型输出的网络参数,使其逼近或达到最优值,从而最小化(或最大化)损失函数。 总结 从SGD到Adam做了哪些改进自适应的学习率、动量 从SGD到Adam做了哪些改进Adamw 即 Adam + weight decate ,效果与 Adam + L2正则化相同,但是计算效率更高,因为L2正则…

css--踩坑

1. 子元素的宽高不生效问题 设置flex布局后,子元素的宽高不生效问题。 如果希望子元素的宽高生效,解决方法,给子元素添加如下属性: flex-shrink: 0; flex-shrink: 0;2. 横向滚动(子元素宽度不固定) /* tab…

Centos7升级OpenSSH9.1

最近遇到了服务器漏洞,需要对服务器的OpenSSH版本进行升级,查阅了相关资料,总结出了一套比较简单的方案。中间遇到的个别问题也进行了记录,供大家参考。 下载准备 从https://ftp.jaist.ac.jp/pub/OpenBSD/OpenSSH/portable/opens…

mysql 逻辑备份 恢复数据

一、逻辑备份 逻辑备份:备份的是建表,建库,插入数据等操作所执行SQL语句,适用于中小型数据库,效率相对较低,提供三种级别的备份,表级,库级和全库级。 本质:导出的是SQL语…

【外汇天眼】携手共护外汇投资:2023年WikiFX晚宴首次在越南圆满举行

9月23日,WikiFX在越南与Wsaas合作举办了一场晚宴,以此表达对合作伙伴的感谢。此次晚会不仅仅是各位行业精英聚一起分享经验、了解行业动向的机会,也是WikiFX在越南分部第一次思考与复盘的活动。 回顾过去——WikiFX在越南的四年 从2019年开始…

linearlayout中使用多个weight导致部分子控件消失异常

问题描述: 在一个linearlayout中写了两个用到weight的布局,在androidstudio中显示正常 但是代码跑起来之后最下面哪一行都消失了; 解决办法1 把两个用到weight的改成一个了,外面那层的weight写成固定宽度就能正常显示出丢失的…

软件设计师考试错题

删除线格式 1. 192.168.37.192/25是什么地址 知识点:主机号全为0的ip成为网络地址,全为1的ip地址成为定向广播地址,都不能做源地址。 192.168.37.192/25表示前25位为网络号,后7位为主机号,192.168.37.11000000 2. 如果…

LRU 缓存 -- 哈希链表

相关题目 146. LRU 缓存 要让 put 和 get ⽅法的时间复杂度为 O(1),我们可以总结出 cache 这个数据结构必要的条件: 1、显然 cache 中的元素必须有时序,以区分最近使⽤的和久未使⽤的数据,当容量满了之后要删除最久未使⽤的那个元…

Shibuya109 109 可穿戴系列来啦!

准备好用 “SHIBUYA109”可穿戴系列来提升你们的时尚感。该系列包含各种时尚相关单品,从 9 月 26 日起也将在 SHIBUYA109 体验中提供。用大量尖端的日本时尚单品来装扮你的人物化身吧。 探索元宇宙中 SHIBUYA109 的世界,穿上可爱的时尚单品,…

python scanpy spatial空转全流程

Spatial mapping of cell types across the mouse brain (1/3) - estimating reference expression signatures of cell types — cell2location documentation Spatial mapping of cell types across the mouse brain (2/3) - cell2location — cell2location documentation #…