


So verwenden Sie ein Python-Skript, um automatisch Bilder und Screenshots aufzunehmen und E-Mail-Benachrichtigungen zu senden, nachdem der Computer aufgewacht ist
背景
背景是这样的, 我的家里台式机常年 休眠, 并配置了 Wake On Lan (WOL) 方便远程唤醒并使用.
但是我发现, 偶尔台式机会被其他情况唤醒, 这时候我并不知道, 结果白白运行了好几天, 浪费了很多电.
所以我的需求是这样的:
电脑唤醒后(可能是开机, 有可能是从休眠状态唤醒), 自动做如下几件事:
摄像头拍照(判断是不是有人在使用)
屏幕截图(判断是不是有人在使用)
生成一封邮件, 告诉我「电脑已启动」并附上拍照和截图;
发送到我的邮箱.
具体实现
️ 摄像头拍照
概述:
通过
opencv-python
包实现.
具体的包名为: opencv-python
依赖 numpy
所以安装命令为:
python -m pip install numpy python -m pip install opencv-python
然后导入语句为: import cv2
源码如下:
# 打开摄像头并拍照 cap = cv2.VideoCapture(0) # 0 表示打开 PC 的内置摄像头(若参数是视频文件路径则打开视频) # 按帧读取图片或视频 # ret,frame 是 cap.read() 方法的两个返回值。 # 其中 ret 是布尔值,如果读取帧是正确的则返回 True,如果文件读取到结尾,它的返回值就为 False。 # frame 就是每一帧的图像,是个三维矩阵。 ret, frame = cap.read() # 按帧读取图片 cv2.imwrite('p1.jpg', frame) # 保存图像 cap.release() # 释放(关闭)摄像头
屏幕截图
概述:
通过
pyautogui
包实现.
pyautogui 是比较简单的,但是不能指定获取程序的窗口,因此窗口也不能遮挡,不过可以指定截屏的位置,0.04s 一张截图,比 PyQt 稍慢一点,但也很快了。
import pyautogui import cv2 # 截图 screen_shot = pyautogui.screenshot() screen_shot.save('screenshot.png')
写邮件
概述:
通过
MIMEMultipart
类型
MIME 邮件中各种不同类型的内容是分段存储的,各个段的排列方式、位置信息都通过 Content-Type
域的 multipart
类型来定义。 multipart
类型主要有三种子类型:
mixed
: 附件alternative
: 纯文本和超文本内容related
:内嵌资源. 比如:在发送 html 格式的邮件内容时,可能使用图像作为 html 的背景,html 文本会被存储在alternative
段中,而作为背景的图像则会存储在related
类型定义的段中
具体源码如下:
from email.mime.multipart import MIMEMultipart from email.mime.text import MIMEText from email.mime.image import MIMEImage sender = 'admin@example.com' # 发件人 receivers = 'admin@example.com' # 收件人 pw = 'p@ssw0rd' # 三方客户端登录邮箱授权码 subject = '电脑已启动拍照并发送' # 邮件主题 text = '您好,您的电脑已开机,并拍摄了如下照片:' # 邮件正文 msg = MIMEMultipart('mixed') # 定义含有附件类型的邮件 msg['Subject'] = subject # 邮件主题 msg['From'] = sender # 发件人 msg['To'] = receivers # 收件人 # MIMEText三个参数:第一个为文本内容,第二个 plain 设置文本格式,第三个 utf-8 设置编码 # 构造一个文本邮件对象, plain 原格式输出; html html格式输出 text = MIMEText(text, 'plain', 'utf-8') msg.attach(text) # 将文本内容添加到邮件中 for i in ('p1.jpg', 'screenshot.png'): sendImg = open(i, 'rb').read() # 读取刚才的图片 img = MIMEImage(sendImg) # 构造一个图片附件对象 # 指定下载的文件类型为:附件, 并加上文件名 img['Content-Disposition'] = 'attachment; filename={}'.format(i) msg.attach(img) # 将附件添加到邮件中 msg_tsr = msg.as_string() # 将msg对象变为str
️ 发邮件
概述:
通过
smtplib
包实现.
源码如下:
import smtplib # 发送邮件 try: smtp = smtplib.SMTP() # 定义一个SMTP(传输协议)对象 smtp.connect('smtp.example.com', 25) # 连接到邮件发送服务器,默认25端口 smtp.login(sender, pw) # 使用发件人邮件及授权码登陆 smtp.sendmail(sender, receivers, msg_tsr) # 发送邮件 smtp.quit() # 关闭邮箱,退出登陆 except Exception as e: print('\033[31;1m出错了:%s\033[0m' % (e)) else: print('邮件发送成功!')
台式机唤醒后触发 python 脚本
Windows 脚本
Windows bat 脚本如下:
@echo off timeout /T 15 /NOBREAK # sleep 15s cd /d D:\scripts\auto_send_email python auto_email.py # 执行py文件
任务计划程序
进入 计算机管理 -> 系统工具 -> 任务计划程序. 添加如下任务计划:
安全选项:
勾选:
不管用户是否登录都要运行
勾选:
使用最高权限运行
触发器:
发生事件时
日志:
系统
源:
Power-Troubleshooter
事件 ID:
1
操作: 启动程序:
D:\scripts\auto_email.bat
Das obige ist der detaillierte Inhalt vonSo verwenden Sie ein Python-Skript, um automatisch Bilder und Screenshots aufzunehmen und E-Mail-Benachrichtigungen zu senden, nachdem der Computer aufgewacht ist. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



PHP und Python haben ihre eigenen Vor- und Nachteile, und die Wahl hängt von den Projektbedürfnissen und persönlichen Vorlieben ab. 1.PHP eignet sich für eine schnelle Entwicklung und Wartung großer Webanwendungen. 2. Python dominiert das Gebiet der Datenwissenschaft und des maschinellen Lernens.

Docker verwendet Linux -Kernel -Funktionen, um eine effiziente und isolierte Anwendungsumgebung zu bieten. Sein Arbeitsprinzip lautet wie folgt: 1. Der Spiegel wird als schreibgeschützte Vorlage verwendet, die alles enthält, was Sie für die Ausführung der Anwendung benötigen. 2. Das Union File System (UnionFS) stapelt mehrere Dateisysteme, speichert nur die Unterschiede, speichert Platz und beschleunigt. 3. Der Daemon verwaltet die Spiegel und Container, und der Kunde verwendet sie für die Interaktion. 4. Namespaces und CGroups implementieren Container -Isolation und Ressourcenbeschränkungen; 5. Mehrere Netzwerkmodi unterstützen die Containerverbindung. Nur wenn Sie diese Kernkonzepte verstehen, können Sie Docker besser nutzen.

Aktivieren Sie die Pytorch -GPU -Beschleunigung am CentOS -System erfordert die Installation von CUDA-, CUDNN- und GPU -Versionen von Pytorch. Die folgenden Schritte führen Sie durch den Prozess: Cuda und Cudnn Installation Bestimmen Sie die CUDA-Version Kompatibilität: Verwenden Sie den Befehl nvidia-smi, um die von Ihrer NVIDIA-Grafikkarte unterstützte CUDA-Version anzuzeigen. Beispielsweise kann Ihre MX450 -Grafikkarte CUDA11.1 oder höher unterstützen. Download und installieren Sie Cudatoolkit: Besuchen Sie die offizielle Website von Nvidiacudatoolkit und laden Sie die entsprechende Version gemäß der höchsten CUDA -Version herunter und installieren Sie sie, die von Ihrer Grafikkarte unterstützt wird. Installieren Sie die Cudnn -Bibliothek:

Python und JavaScript haben ihre eigenen Vor- und Nachteile in Bezug auf Gemeinschaft, Bibliotheken und Ressourcen. 1) Die Python-Community ist freundlich und für Anfänger geeignet, aber die Front-End-Entwicklungsressourcen sind nicht so reich wie JavaScript. 2) Python ist leistungsstark in Bibliotheken für Datenwissenschaft und maschinelles Lernen, während JavaScript in Bibliotheken und Front-End-Entwicklungsbibliotheken und Frameworks besser ist. 3) Beide haben reichhaltige Lernressourcen, aber Python eignet sich zum Beginn der offiziellen Dokumente, während JavaScript mit Mdnwebdocs besser ist. Die Wahl sollte auf Projektbedürfnissen und persönlichen Interessen beruhen.

Minio-Objektspeicherung: Hochleistungs-Bereitstellung im Rahmen von CentOS System Minio ist ein hochleistungsfähiges, verteiltes Objektspeichersystem, das auf der GO-Sprache entwickelt wurde und mit Amazons3 kompatibel ist. Es unterstützt eine Vielzahl von Kundensprachen, darunter Java, Python, JavaScript und Go. In diesem Artikel wird kurz die Installation und Kompatibilität von Minio zu CentOS -Systemen vorgestellt. CentOS -Versionskompatibilitätsminio wurde in mehreren CentOS -Versionen verifiziert, einschließlich, aber nicht beschränkt auf: CentOS7.9: Bietet einen vollständigen Installationshandbuch für die Clusterkonfiguration, die Umgebungsvorbereitung, die Einstellungen von Konfigurationsdateien, eine Festplattenpartitionierung und Mini

Die Installation von CentOS-Installationen erfordert die folgenden Schritte: Installieren von Abhängigkeiten wie Entwicklungstools, PCRE-Devel und OpenSSL-Devel. Laden Sie das Nginx -Quellcode -Paket herunter, entpacken Sie es, kompilieren Sie es und installieren Sie es und geben Sie den Installationspfad als/usr/local/nginx an. Erstellen Sie NGINX -Benutzer und Benutzergruppen und setzen Sie Berechtigungen. Ändern Sie die Konfigurationsdatei nginx.conf und konfigurieren Sie den Hörport und den Domänennamen/die IP -Adresse. Starten Sie den Nginx -Dienst. Häufige Fehler müssen beachtet werden, z. B. Abhängigkeitsprobleme, Portkonflikte und Konfigurationsdateifehler. Die Leistungsoptimierung muss entsprechend der spezifischen Situation angepasst werden, z. B. das Einschalten des Cache und die Anpassung der Anzahl der Arbeitsprozesse.

Pytorch Distributed Training on CentOS -System erfordert die folgenden Schritte: Pytorch -Installation: Die Prämisse ist, dass Python und PIP im CentOS -System installiert sind. Nehmen Sie abhängig von Ihrer CUDA -Version den entsprechenden Installationsbefehl von der offiziellen Pytorch -Website ab. Für CPU-Schulungen können Sie den folgenden Befehl verwenden: PipinstallTorChTorChVisionTorChaudio Wenn Sie GPU-Unterstützung benötigen, stellen Sie sicher, dass die entsprechende Version von CUDA und CUDNN installiert ist und die entsprechende Pytorch-Version für die Installation verwenden. Konfiguration der verteilten Umgebung: Verteiltes Training erfordert in der Regel mehrere Maschinen oder mehrere Maschinen-Mehrfach-GPUs. Ort

Die Gründe für die Installation von VS -Code -Erweiterungen können sein: Netzwerkinstabilität, unzureichende Berechtigungen, Systemkompatibilitätsprobleme, VS -Code -Version ist zu alt, Antiviren -Software oder Firewall -Interferenz. Durch Überprüfen von Netzwerkverbindungen, Berechtigungen, Protokolldateien, Aktualisierungen von VS -Code, Deaktivieren von Sicherheitssoftware und Neustart von Code oder Computern können Sie Probleme schrittweise beheben und beheben.
