Python自动工作汇报脚本,闲到每天被迫摸鱼~

2023-10-07 06:40

本文主要是介绍Python自动工作汇报脚本,闲到每天被迫摸鱼~,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

嗨害大家好鸭~ 我是小熊猫❤

好久不见~ 一点都不想念呢~

最近也有在好好工作吗?

不管有没有,我知道大家的工作状态大概是这样的:

请添加图片描述

请添加图片描述
之前经常编写Python脚本来进行数据处理、数据传输和模型训练。

随着数据量和数据复杂性的增加,

运行脚本可能需要一些时间。

在等待数据处理完成时可以同时做一些其他工作。

为了达到这个目的,

编写了一组用于解决这个问题的Python脚本。

使用这些脚本向手机发送流程更新、可视化和完成通知。

当偶尔拥有这些自由的时刻,

你可以享受而不是担心模型的进度。

请添加图片描述

有什么python相关报错解答自己不会的、或者源码资料/模块安装/女装大佬精通技巧 都可以来这里:(https://jq.qq.com/?_wv=1027&k=2Q3YTfym)或者+V:python10010问我

需要什么💦

第一个问题是,需要知道什么?

这取决于你正在做的工作。

对于本熊猫来说主要有有三个可能会占用时间的处理任务:

  • 模型训练
  • 数据处理和/或传输
  • 金融模型

我们需要对于每一种情况具体分析。

请添加图片描述

模型训练❤

更新每n个epoch,必须包括关键指标。

例如,训练和验证集的损失和准确性。

接着完成通知,包括:

  • 训练期间关键指标的可视化(同样,训练和验证集的损失和准确性)
  • 其他不太重要但仍然有用的信息,如本地模型目录、训练时间、模型架构等
  • 预测输出,对于文本生成来说输出生成的文本(或它的一个样本);对于图像生成来说,输出结果是一个(希望)很酷的可视化

以训练一个神经网络来重现给定的艺术风格为例。

我们需要重点从模型中生成的图像,损失和精度图,当前的训练时间,和一个模型的名称。

import notifySTART= datetime.now()  # this line would be placed before modeltraining beginsMODELNAME="SynthwaveGAN"  # giving us ourmodel nameNOTIFY=100  # so we send an update notification every100 epochs# for each epoch e,we would include the following codeif e % notify_epoch ==0and e !=0:# here we createthe email body messagetxt = (f"{MODELNAME} update as of "f"{datetime.now().strftime( %H:%M:%S )}.")# we build theMIME message object with notify.messagemsg = notify.message(subject= Synthwave GAN ,text=txt,img=[f ../visuals/{MODELNAME}/epoch_{e}_loss.png ,f ../visuals/{MODELNAME}/epoch_{e}_iter_{i}.png ])  # note that weattach two images here, the loss plot and#    ...a generated image output from our modelnotify.send(msg)  # we then send the message

每隔100个epoch,就会发送一封包含上述所有内容的电子邮件。

以下是其中一封邮件:

请添加图片描述
请添加图片描述

数据传输和处理❤

这点不是很有趣,但在时间消耗方面,它排第一名。

以使用Python将批量数据上传到SQLServer为例(对于没有BULK INSERT的人)。

在上传脚本的最后,会有一个简单的消息通知上传完成。

import osimport notifyfrom data importSql  # seehttps://jamescalam.github.io/pysqlplus/lib/data/sql.htmldt =Sql( database123 ,  server001 )  # setup theconnection to SQL Serverfor i, file inenumerate(os.listdir( ../data/new )):dt.push_raw(f ../data/new/{file} )  # push a file to SQL Server# once the upload is complete, send a notification# first we create the messagemsg = notify.message(subject= SQL Data Upload ,text=f Data upload complete, {i} filesuploaded. ,)# send the messagenotify.send(msg)

如果偶尔抛出错误,还可以添加一个try-except语句来捕获错误,并将其添加到一个列表中,以包含在更新和/或完成电子邮件中。

请添加图片描述

金融模型❤

金融建模中运行的所有东西实际上都非常快,所以此处只能提供一个示例。

现金流动模型工具 为例。

现实中,这个过程只需要10-20秒,但现在假设你是华尔街炙手可热的定量分析师,正在处理几百万笔贷款。

在这封电子邮件中,可能想要包含一个高级概要分析的投资组合。

可以随机选择一些贷款,并在给定的时间段内可视化关键值——给定一个小样本来交叉检验模型的性能。

end = datetime.datetime.now()  # get the ending datetime# get the total runtime in hours:minutes:secondshours,rem =divmod((end - start).seconds, 3600)mins,secs =divmod(rem, 60)runtime= {:02d}:{:02d}:{:02d} .format(hours, mins,secs)# now built our messagenotify.msg(subject="Cashflow Model Completion",text=(f {len(model.output)} loansprocessed. f Total runtime:{runtime} ),img=[../vis/loan01_amortisation.png ,../vis/loan07_amortisation.png ,../vis/loan01_profit_and_loss.png ,../vis/loan07_profit_and_loss.png ])notify.send(msg)  # and send it

代码❤

上面的所有功能节选自一个名为notify.py的脚本。

在示例代码中将使用Outlook。

这里需要两个Python库,email和smtplib:

  • email :用于管理电子邮件消息。有了这个库就可以设置电子邮件消息本身,包括主题、正文和附件。
  • smtplib :处理SMTP连接。简单邮件传输协议(SMTP)是大多数电子邮件系统使用的协议,允许邮件通过互联网发送。

请添加图片描述
请添加图片描述

MIME❤

消息本身是使用来自email模块的MIMEMultipart对象构建的。还需要使用三个MIME子类,并将它们附加到MIMEMultipart对象上:

  • mimetext:这将包含电子邮件“有效负载”,即电子邮件正文中的文本。
  • mimeimage :这是用于在电子邮件中包含图像。
  • mimeapplication:用于MIME消息应用程序对象。也就是文件附件。

除了这些子类之外,还有其他参数,比如MimeMultipart中的Subject值。所有这些加在一起就形成了下面的结构。

把它们都放在一起会发生什么:

请添加图片描述

import osfrom email.mime.text importMIMETextfrom email.mime.image importMIMEImagefrom email.mime.application importMIMEApplicationfrom email.mime.multipart importMIMEMultipartdefmessage(subject="PythonNotification", text="", img=None, attachment=None):# build messagecontentsmsg =MIMEMultipart()msg[ Subject ] = subject  # add in thesubjectmsg.attach(MIMEText(text))  # add text contents# check if wehave anything given in the img parameterif img isnotNone:# if we do, wewant to iterate through the images, so let s check that# what we haveis actually a listiftype(img) isnot list:img = [img]  # if it isn t alist, make it one# now iteratethrough our listfor one_img in img:img_data =open(one_img,  rb ).read()  # read the imagebinary data# attach theimage data to MIMEMultipart using MIMEImage, we add# the givenfilename use os.basenamemsg.attach(MIMEImage(img_data, name=os.path.basename(one_img)))# we do the samefor attachments as we did for imagesif attachment isnotNone:iftype(attachment) isnot list:attachment = [attachment]  # if it isn t a list, make it onefor one_attachment in attachment:withopen(one_attachment, rb ) as f:# read in theattachment using MIMEApplicationfile =MIMEApplication(f.read(),name=os.path.basename(one_attachment))# here we editthe attached file metadatafile[ Content-Disposition ] =f attachment; filename="{os.path.basename(one_attachment)}" msg.attach(file)  # finally, addthe attachment to our message objectreturn msg

这个脚本相当简单。

在顶部,有导入(这是以前介绍过的MIME部分)以及Python的os库。

接下来定义一个名为message的函数。

这允许使用不同的参数调用函数并轻松地构建一个电子邮件消息对象。

例如,可以这样写一封带有多张图片和附件的邮件:

email_msg= message(text="Model processing complete,please see attached data.",img=[ accuracy.png ,  loss.png ],attachments=[ data_in.csv ,  data_out.csv ]
)

首先,初始化MIMEMultipart对象,并将其分配给msg;

然后,使用“subject”键设置电子邮件主题。

attach方法向MIMEMultipart对象添加不同的MIME子类。

你可以使用MIMEText子类添加电子邮件正文。

对于图像img和attachment附件,可以什么都不传递,只传递一个文件路径,或者传递一组文件路径。

我们通过首先检查参数是否为None来处理它,如果参数为None,则传递;否则,检查给定的数据类型,不是一个list,就创建一个,这就使得可以用下面的for循环来遍历项。

接着,使用MIMEImage和MIMEApplication子类分别附加图像和文件。

使用os.basename从给定的文件路径中获取文件名,附件名包括该文件名。

请添加图片描述

SMTP❤

现在已经构建好电子邮件消息对象,下一步就是发送它。这就是smtplib模块发挥作用的地方。代码同样非常简单,只有一处例外。

由于直接处理不同的电子邮件供应商和他们各自的服务器,需要不同的SMTP地址。在谷歌中输入“outlook smtp”。不需要单击页面,你就可以得到服务器地址smtp-mail.outlook.com和端口号587。

当使用smtplib.SMTP初始化SMTP对象时,这两种方法都需要用。SMTP -接近开始的send函数:

import smtplibimport socketdefsend(server= smtp-mail.outlook.com , port= 587 , msg):# contain followingin try-except in case of momentary network errorstry:# initialiseconnection to email server, the default is Outlooksmtp = smtplib.SMTP(server, port)# this is the Extended Hello  command, essentially greeting our SMTP or ESMTP serversmtp.ehlo()# this is the Start Transport Layer Security  command, tells the server we will# becommunicating with TLS encryptionsmtp.starttls()# read email andpassword from filewithopen( ../data/email.txt ,  r ) as fp:email = fp.read()withopen( ../data/password.txt ,  r ) as fp:pwd = fp.read()# login tooutlook serversmtp.login(email, pwd)# sendnotification to selfsmtp.sendmail(email, email, msg.as_string())# disconnectfrom the serversmtp.quit()except socket.gaierror:print("Network connection error, email notsent.")

smtp.ehlo()和smtp.starttls()都是SMTP命令。ehlo(扩展Hello)本质上是向服务器打招呼。starttls通知服务器,将使用加密传输级别安全(TLS)连接进行通信。

在此之后,只需从文件中读取电子邮件和密码,分别存储在email和pwd中。然后,使用smtp.login登录到SMTP服务器。登录并使用smtp.sendmail发送电子邮件。

笔者总是给自己发送通知,但在自动报告的情况下,可能希望将电子邮件发送到其他地方。为此,我会更改destination_address: smtp.sendmail(email、destination_address、 msg.as_string)。

最后,终止会话并关闭与smtp.quit的连接。

将所有这些都放在try-except语句中。在瞬间网络连接丢失的情况下,将无法连接到服务器。导致socket.gaierror。使用try-except语句可以防止程序在网络连接失败的情况下崩溃。

笔者将其用于ML模型培训更新和数据传输完成。如果邮件没有被发送,那也没有关系。这种简单、被动地处理连接丢失是合适的。
请添加图片描述

放在一起💜

现在已经写了代码的两部分,我们就可以发送电子邮件了:

 # builda message object
msg = message(text="See attached!", img= important.png ,attachment= data.csv )send(msg)  #send the email (defaults to Outlook)

这是所有的电子邮件通知和/或使用Python的自动化的全过程。感谢email和smptlib库,设置过程变得非常容易。

请添加图片描述
还有一点请注意,公共电子邮件提供程序服务器地址和TLS端口。

对于任何耗费大量时间的处理或训练任务,进度更新和完成通知通常才是真正的解放。Python,让工作更美好!

兄弟们学习python,有时候不知道怎么学,从哪里开始学。掌握了基本的一些语法或者做了两个案例后,不知道下一步怎么走,不知道如何去学习更加高深的知识。
那么对于这些大兄弟们,我准备了大量的资料,PDF电子书籍,以及源代码!都在下方名片了

今天的文章就到这里啦~ 看到这都不点个赞?

我是小熊猫,咱下篇文章再见啦(✿◡‿◡)

请添加图片描述

这篇关于Python自动工作汇报脚本,闲到每天被迫摸鱼~的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

每天认识几个maven依赖(ActiveMQ+activemq-jaxb+activesoap+activespace+adarwin)

八、ActiveMQ 1、是什么? ActiveMQ 是一个开源的消息中间件(Message Broker),由 Apache 软件基金会开发和维护。它实现了 Java 消息服务(Java Message Service, JMS)规范,并支持多种消息传递协议,包括 AMQP、MQTT 和 OpenWire 等。 2、有什么用? 可靠性:ActiveMQ 提供了消息持久性和事务支持,确保消

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',