用Python对CSV文件进行处理并生成符合要求的图表,在图表上继续截取符合条件的y值并进行功率P的计算

本文主要是介绍用Python对CSV文件进行处理并生成符合要求的图表,在图表上继续截取符合条件的y值并进行功率P的计算,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实习任务2:在实习任务1的基础上并在给定的电流的情况下确定其功率并用图表显示出来
计算公式为 P= I*U
代码如下:

from matplotlib import pyplot as plt
import csv
import glob
import numpy as np
from os.path import basenamefor n in range(9,14):           #Dateien von Modul_9 bis zu Modul_13plt.figure(1)               # Subdiagramm 1 plottenplt.figure(dpi = 128, figsize=(10,6))ax1 = plt.subplot(121)                                                                                                      plt.title("PIDrecovery_I-V_Kennlinie",fontsize = 16)plt.xlabel("Spannnung [V]", fontsize = 16)plt.ylabel("Strom [A]", fontsize = 16)def name_konfiguration(n):  # beim Name von Modul_9 muss noch ein '0' davor einfuegenif n == 9:return str("09")else:return str(n)files = sorted(glob.glob("F:\Python_Aufgabe\Aufgabe_2\P09-P13_PIDre\DIV_CSP_PIDre_MZ_2_P" + name_konfiguration(n) + "*.csv"))     #list of filesprint("processin raw files")mpp_liste= []               # eine liste fuer MPP erstellenfor file in files:filename = basename(file).rsplit('.', 1)[0]      # each file in list of files                                                     print('\r'+ filename + "  ", flush = True)     # progress informationwith open(file) as f:    #'with' will auto close after loopcsvreader = csv.reader(f, delimiter = ",", quotechar='"')     #read into csv objectfor line in range(48):      #skip header                             next (csvreader)                                                                            voltage = []        #init lists      current = []for row in csvreader:voltage.append(float(row[6]))      #process each rowcurrent.append(float(row[3]))        #extract column           Imp = np.linspace(9,9,len(voltage))     # Isc auf dem Diagramm anzeigen                                                            idx = np.argwhere(np.diff(np.sign(Imp - current))).flatten() # entsprchende X-wert einsammelnprint(int(idx))print(float(np.array(current,dtype=np.float)[idx]))print(float(np.array(voltage,dtype=np.float)[idx]))get_mpp=float(np.array(current,dtype=np.float)[idx] * np.array(voltage,dtype=np.float)[idx]) # multiplizierenmpp_liste.append(get_mpp)           # die Liste von MPP ausfuellenprint("MPP: " + str(get_mpp))print("mpp_liste: " + str(mpp_liste[:]))plt.plot(voltage,Imp, label= filename)   #actual plotplt.plot(voltage, current)plt.plot(np.array(voltage,dtype=np.float)[idx], np.array(Imp,dtype=np.float)[idx], 'ro')       # kritische Punkte  auf dem Diagramm anzeigen                                                                            plt.legend()ax2 = plt.subplot(122)          # Subdiagramm 2 plottenplt.title("MPP_Kennlinie",fontsize = 16)plt.xlabel("Datei_nummer", fontsize = 16)plt.ylabel("MPP[W]", fontsize = 16)file_number= np.linspace(1,13,len(mpp_liste))        plt.plot(np.array(file_number),np.array(mpp_liste), label="DIV_CSP_PIDre_MZ_2_P" + name_konfiguration(n) + "MPP_Kennlinie")plt.legend()print("Done processing " + str(len(files)) + " files.")       #final informationplt.savefig("F:\Python_Aufgabe\Aufgabe_2\P09-P13_PIDre\DIV_CSP_PIDre_MZ_2_P" + name_konfiguration(n) + ".png", dpi = 300)    #save plot as file
plt.show()       #present plot     

这是针对光伏模块09的描述图在这里插入图片描述

这篇关于用Python对CSV文件进行处理并生成符合要求的图表,在图表上继续截取符合条件的y值并进行功率P的计算的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/694273

相关文章

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

linux解压缩 xxx.jar文件进行内部操作过程

《linux解压缩xxx.jar文件进行内部操作过程》:本文主要介绍linux解压缩xxx.jar文件进行内部操作,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、解压文件二、压缩文件总结一、解压文件1、把 xxx.jar 文件放在服务器上,并进入当前目录#

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过