Python办公自动化【Windows中定时任务、OS/linux 系统定时任务 、Python 钉钉发送消息、Python 钉钉发送图片】(九)-全面详解(学习总结---从入门到深化)

简介: Python办公自动化【Windows中定时任务、OS/linux 系统定时任务 、Python 钉钉发送消息、Python 钉钉发送图片】(九)-全面详解(学习总结---从入门到深化)



Windows中定时任务

定时任务最主要的功能 ,就是帮助我们在指定的时间运行某个程序或者脚本。比如:

1、定期发送邮件

2、定期统计工资情况

3、定期汇总文件

4、定期清理文件

Windows进入定时任务的方法为: 右键“此电脑”-----> 管理 -----> 系统工具 -----> 任务计划程序

快捷键

Windows 键+R,调出"运行窗口",输入 compmgmt.msc

OS/linux 系统定时任务

crontab

1、-e 编辑工作表

2、-l 列出工作表里的命令

3、-r 删除工作表

crontab 的命令构成为 时间+动作,其时间有分、时、日、月、周 五种,操作符有

1、取值范围内的所有数字

2、/ 每过多少个数字

3、- 从 X 到 Z

4、散列数字

注意

crontab 新增了任务后,重启下服务,命令如下: /etc/init.d/cron restart

案例

实例 1:每 1 分钟执行一次 myCommand

\* * * * * myCommand  

实例 2:每小时的第 3 和第 15 分钟执行

3,15 * * * * myCommand  

实例 3:在上午 8 点到 11 点的第 3 和第 15 分钟执行

3,15 8-11 * * * myCommand  

实例 4:每隔两天的上午 8 点到 11 点的第 3 和第 15 分钟执行

3,15 8-11 */2 * * myCommand

实例 5:每周一上午 8 点到 11 点的第 3 和第 15 分钟执行

3,15 8-11 * * 1 myCommand

实例 6:每晚的 21:30 重启 smb

30 21 * * * /etc/init.d/smb restart

实例 7:每月 1、10、22 日的 4 : 45 重启 smb

45 4 1,10,22 * * /etc/init.d/smb restart

实例 8:每周六、周日的 1 : 10 重启 smb

10 1 * * 6,0 /etc/init.d/smb restart

实例 9:每天 18 : 00 至 23 : 00 之间每隔 30 分钟重启 smb

0,30 18-23 * * * /etc/init.d/smb restart

实例 10:每星期六的晚上 11 : 00 pm 重启 smb

0 23 * * 6 /etc/init.d/smb restart

实例 11:每一小时重启 smb

\* */1 * * * /etc/init.d/smb restart

实例 12:晚上 11 点到早上 7 点之间,每隔一小时重启 smb

\* 23-7/1 * * * /etc/init.d/smb restart

Python 钉钉发送消息

创建钉钉机器人

安装

pip install dingtalkchatbot

常用方法与属性

函数名&属性 含义
dingtalkchatbot.chatbot.DingtalkChatbot  创建机器人
chatbot.send_text()  发送消息
chatbot.send_image()  发送图片
chatbot.send_link() 发送链接
chatbot.send_markdown() 发送Markdown文档

代码

from dingtalkchatbot.chatbot import DingtalkChatbot
def send_text():
 # 创建一个机器人
  webhook = 'https://oapi.dingtalk.com/robot/send?access_token=5a6e68c7a3c146c4b37126cbd434ffaf6b11bc7763ac91136130a38dbd25ae83'
  secret = 'SEC63299e56a96cb2a24b9b67834bc9df3498963f101e9800a9fa7bdc76c3240228'
  bot = DingtalkChatbot(webhook,secret)
  # 发送消息
  # bot.send_text('大家好~我是小童小助手~')
  # bot.send_text('大家该交作业啦~')
  # bot.send_text('要开会啦~',is_at_all=True)
  bot.send_text('你之前问题搞定了没有?',at_mobiles=[1668888888])
if __name__ =='__main__':
  send_text()

Python 钉钉发送图片

常用方法与属性

函数名&属性  含义
dingtalkchatbot.chatbot.DingtalkChatbot 创建机器人
chatbot.send_image() 发送图片

代码

from dingtalkchatbot.chatbot import DingtalkChatbot
def send_img():
  webhook = 'https://oapi.dingtalk.com/robot/send?access_token=5a6e68c7a3c146c4b37126cbd434ffaf6b11bc7763ac91136130a38dbd25ae83'
  secret = 'SEC63299e56a96cb2a24b9b67834bc9df3498963f101e9800a9fa7bdc76c3240228'
  # 创建机器人
  bot = DingtalkChatbot(webhook,secret)
  # 发送图片消息
 bot.send_image('https://www.itbaizhan.com/public/new/index/images/courimg2.jpg')
if __name__ =='__main__':
  send_img()

Python钉钉发送链接与MarkDown

常用方法与属性

函数名&属性  含义
dingtalkchatbot.chatbot.DingtalkChatbot 创建机器人
chatbot.send_link()  发送链接
chatbot.send_markdown()  发送Markdown文档

代码

from dingtalkchatbot.chatbot import DingtalkChatbot
def send_link():
  webhook = 'https://oapi.dingtalk.com/robot/send?access_token=5a6e68c7a3c146c4b37126cbd434ffaf6b11bc7763ac91136130a38dbd25ae83'
  secret = 'SEC63299e56a96cb2a24b9b67834bc9df3498963f101e9800a9fa7bdc76c3240228'
  # 创建机器器
 chart_bot = DingtalkChatbot(webhook,secret)
  # 发送链接
  chart_bot.send_link(
    title='Python自动化课程',
    text='欢迎学习Python课程',
  message_url='http://www.baidu.cn',
 pic_url='https://www.baidu.com/public/new/index/images/courimg3.jpg')
def send_markdown():
  webhook = 'https://oapi.dingtalk.com/robot/send?access_token=5a6e68c7a3c146c4b37126cbd434ffaf6b11bc7763ac91136130a38dbd25ae83'
  secret = 'SEC63299e56a96cb2a24b9b67834bc9df3498963f101e9800a9fa7bdc76c3240228'
  # 创建机器器
  chart_bot = DingtalkChatbot(webhook,secret)
  # 发送markdown
  chart_bot.send_markdown(
    title='Python自动化课程',
    text='### 欢迎学习Python课程\n'
    '此课程我们安排了word、excle、ptt 等.....'
    '![Python] (https://www.baidu.com/public/new/index/images/couimg1.jpg)' )
if __name__ =='__main__':
  # send_link()
  send_markdown()

Python钉钉发送卡片消息

常用方法与属性

函数名&属性 含义
dingtalkchatbot.chatbot.DingtalkChatbot  创建机器人
dingtalkchatbot.chatbot.CardItem(title,url,pic_url)  卡片消息对象
chatbot.send_feed_card()  发送卡片消息

代码

from dingtalkchatbot.chatbot import DingtalkChatbot
from dingtalkchatbot.chatbot import CardItem
def send_card():
  webhook = 'https://oapi.dingtalk.com/robot/send?
access_token=5a6e68c7a3c146c4b37126cbd434ffaf6b11bc7763ac91136130a38dbd25ae83'
  secret = 'SEC63299e56a96cb2a24b9b67834bc9df3498963f101e9800a9fa7bdc76c3240228'
  # 创建机器人
  chat_bot = DingtalkChatbot(webhook,secret)
  # 创建卡片对象
  card1 = CardItem(title='氧眼美女',url='http://www.baidu.cn',pic_url='https://pic.netbian.com/uploads/allimg/220511/003034-16522002340d03.jpg')
  card2 = CardItem(title='氧眼风景',url='http://www.baidu.cn',pic_url='https://pic.netbian.com/uploads/allimg/180826/113958-1535254798fc1c.jpg')
  card3 = CardItem(title='氧眼漫画',url='http://www.baidu.cn',pic_url='https://pic.netbian.com/uploads/allimg/210831/102129-16303764895142.jpg')
  # 发送卡片消息
 chat_bot.send_feed_card([card1,card2,card3]
)
if __name__ =='__main__':
  send_card()

Python钉钉发送互动卡片消息

常用方法与属性

函数名&属性 含义
dingtalkchatbot.chatbot.DingtalkChatbot  创建机器人
dingtalkchatbot.chatbot.ActionCard(title,text,btns)  互动类型卡片消息对象
dingtalkchatbot.chatbot.CardItem(title,url)  卡片消息对象
chatbot.send_action_card()  发送互动卡片消息

代码

from dingtalkchatbot.chatbot import DingtalkChatbot,CardItem
from dingtalkchatbot.chatbot import ActionCard
def send_card():
  webhook = 'https://oapi.dingtalk.com/robot/send?access_token=5a6e68c7a3c146c4b37126cbd434ffaf6b11bc7763ac91136130a38dbd25ae83'
  secret = 'SEC63299e56a96cb2a24b9b67834bc9df3498963f101e9800a9fa7bdc76c3240228'
  # 创建机器人
  chat_bot = DingtalkChatbot(webhook,secret)
  # 创建一个选项
  card1 = CardItem(title='查看详情',url='http://www.baidu.cn')
  # 创建互动卡片对象
  action_card = ActionCard(
    title='万万没想到,竟然...',
    text='![选择] (https://pic.netbian.com/uploads/allimg/210317/001935-16159115757f04.jpg) \n### 故事是这样子的...',
    btns=(card1,),
    btn_orientation = 1,   # 只有2个按钮的时候好用
    hide_avatar=1
 )
  # 发送卡片消息
  chat_bot.send_action_card(action_card)
def send_card2():
  webhook = 'https://oapi.dingtalk.com/robot/send?access_token=5a6e68c7a3c146c4b37126cbd434ffaf6b11bc7763ac91136130a38dbd25ae83'
  secret = 'SEC63299e56a96cb2a24b9b67834bc9df3498963f101e9800a9fa7bdc76c3240228'
  # 创建机器人
  chat_bot = DingtalkChatbot(webhook,secret)
  # 创建一个选项
  card1 = CardItem(title='支持',url='http://www.baidu.cn')
  card2 = CardItem(title='反对',url='http://www.baidu.cn')
  # 创建互动卡片对象
  action_card = ActionCard(
    title='万万没想到,竟然...',
    text='![选择] (https://pic.netbian.com/uploads/allimg/210317/001935-16159115757f04.jpg) \n### 故事是这样子的...',
    btns=(card1,card2),
    btn_orientation = 1,   # 只有2个按钮的时候好用
    hide_avatar=1
 )
  # 发送卡片消息
  chat_bot.send_action_card(action_card)
def send_card3():
   webhook = 'https://oapi.dingtalk.com/robot/send?access_token=5a6e68c7a3c146c4b37126cbd434ffaf6b11bc7763ac91136130a38dbd25ae83'
  secret = 'SEC63299e56a96cb2a24b9b67834bc9df3498963f101e9800a9fa7bdc76c3240228'
  # 创建机器人
  chat_bot = DingtalkChatbot(webhook,secret)
  # 创建一个选项
  card1 = CardItem(title='支持',url='http://www.baidu.cn')
  card2 = CardItem(title='弃票',url='http://www.baidu.cn')
  card3 = CardItem(title='反对',url='http://www.baidu.cn')
  # 创建互动卡片对象
  action_card = ActionCard(
    title='万万没想到,竟然...',
    text='![选择] (https://pic.netbian.com/uploads/allimg/190824/212516-1566653116f355.jpg) \n### 故事是这样子的...',
    btns=(card1,card2,card3),
    btn_orientation = 1,  # 只有2个按钮的时候好用
    hide_avatar=1 )
  # 发送卡片消息
  chat_bot.send_action_card(action_card)
if __name__ =='__main__':
  # send_card()
  # send_card2()
  send_card3()

操作压缩文件 - ZipFile

常用方法与属性

函数名&属性 含义
ZipFile(file,model)  打开压缩文件,w压缩,r解压,a追加
zipFile.write(file)  增加要压缩的文件
zipFile.namelist()  显示压缩包的文件
zipFile.extractall() 解压所有文件

代码

from zipfile import ZipFile
def zip_in():
  # 创建压缩文件
  with
ZipFile('./create_data/12_zip_in.zip','w')
as f:
    # 增加压缩文件
    f.write('./06_task.py')
    f.write('./05_zmail的使用.py')
def zip_out():
 # 打开压缩文件
  with
ZipFile('./create_data/12_zip_in.zip','r')
as f:
    # 读取数据
    print(f.namelist())
    # 解压数据
    f.extractall('./create_data')
if __name__ =='__main__':
  # zip_in()
  zip_out()

Python压缩文件工具开发

需求:给一个指定路径,将其制做成压缩文件

1、路径为文件,直接压缩

2、路径为文件夹,遍历文件夹文件压缩

import os
from zipfile import ZipFile
def new_file(base_path,zip_path):
  # 创建一个压缩文件
  with ZipFile(zip_path,'w') as zip:
    # 通过os.path.isfile() 判断是否是文件
    if os.path.isfile(base_path):
      zip.write(base_path) 
    else:
      # 遍历文件夹
      for root,dirs,files in os.walk(base_path):
        # root 遍历的当前文件夹名称
        # dirs 当前路径包含的文件夹
       # files 当前路径包含的文件
        for f in files:
 zip.write(os.path.join(root,f))
# 在压缩包追加新文件
def add_file(base_path,zip_path):
  # 创建一个压缩文件
  with ZipFile(zip_path,'a') as zip:
    # 通过os.path.isfile() 判断是否是文件
    if os.path.isfile(base_path):
      zip.write(base_path) 
    else:
      # 遍历文件夹
      for root,dirs,files in os.walk(base_path):
        # root 遍历的当前文件夹名称
        # dirs 当前路径包含的文件夹
        # files 当前路径包含的文件
        for f in files:
 zip.write(os.path.join(root,f))
if __name__ =='__main__':
  add_file('05_zmail的使用.py','./create_data/13_压缩工具.zip')

操作压缩文件 - tarfile

常用方法与属性

函数名&属性  含义
tarfile.open(path,model)  打开/创建压缩的文件,model: 'w'写,'r'读,'a'追加
tar.add(path) 增加压缩文件
tar.getmembers()  显示所有的文件信息
tar.extractall()  解压所有文件

代码

import tarfile
def tar_in():
  # 创建压缩文件
  with
tarfile.open('./create_data/14_tarfile.tar','w') as tar:
    # 增加压缩文件
    tar.add('11_发送钉钉互动卡片消息.py')
    tar.add('10_发送钉钉卡片消息.py')
def tar_out():
  # 打开压缩文件
  with
tarfile.open('./create_data/14_tarfile.tar','r') as tar:
    # 获取压缩包里的数据
    # print(tar.getmembers())
    # 解压压缩文件
    tar.extractall('./create_data')
if __name__=='__main__':
  # tar_in()
  tar_out()

暴力破解压缩密码

代码

from zipfile import ZipFile
import os
def passwd(path,pwd):
  type_ = os.path.splitext(path)[-1][1:]
  if type_ == 'zip':
    with ZipFile(path,'r') as zip:
      print(f'正在尝试密码: {pwd}')
      try:
       zip.extractall('./create_data/生成压缩文件',pwd=str(pwd).encode('utf-8'))
        print(f'解压成功,密码是:{pwd}')
        return True
      except Exception as e:
        pass
def create_pwd(length):
  import itertools as its
  words='1234567890asd'
  for i in range(1,length):
    base = its.product(words,repeat=i)
    for i in base:
      yield ''.join(i)
if __name__ == "__main__":
  # passwd('./base_data/aa.zip')
  for p in create_pwd(5):
    flag = passwd('./base_data/aa.zip',p)
    if flag:
      break
目录
相关文章
|
1月前
|
自然语言处理 运维 前端开发
OS Copilot-操作系统智能助手-新手小白入门必选~
作为一名安卓开发工程师,我日常专注于前端和移动端开发。然而,在项目推进中偶尔需要部署服务端,这对不熟悉Linux的我来说颇具挑战。每次用命令行工具操作时,常需频繁查阅命令及参数,效率低下。 幸运的是,我发现了阿里云推出的OS Copilot智能助手。它通过自然语言问答功能,让命令行操作变得轻松流畅,帮助我快速定位并解决问题,显著提升了工作效率。安装简单,配置便捷,支持单命令模式和命令行模式,极大简化了Linux操作,成为我得力的开发利器。 总结而言,OS Copilot让我这个Linux小白也能高效处理服务端任务,操作体验焕然一新,是不可多得的智能助手。
|
4月前
|
测试技术 持续交付 开发者
探索自动化测试的无限可能:从入门到精通
在软件开发领域,确保产品质量是至关重要的。自动化测试作为一种高效、可靠的测试方法,正逐渐成为行业标准。本文将带你深入了解自动化测试的世界,从基础概念到实践技巧,帮助你掌握这一强大的工具。无论你是初学者还是有经验的开发者,都能从中获得宝贵的知识和启发。
|
2月前
|
安全 网络协议 Linux
telnet在windows和linux上的使用方法
Telnet是一个简单且强大的网络工具,广泛用于远程管理和网络诊断。尽管存在安全风险,但在受控环境中,Telnet仍然是一个非常有用的工具。通过本文的介绍,您应该能够在Windows和Linux系统上安装并使用Telnet进行各种网络操作。
193 18
|
2月前
|
Ubuntu 网络协议 Linux
快速部署WSL(Windows Subsystem for Linux)
WSL提供了一种轻量级的方法,使开发者能够在Windows上无缝运行Linux环境。通过本文介绍的步骤,可以快速安装、配置和使用WSL,以满足开发和测试的需求。
205 8
|
3月前
|
Java 测试技术 持续交付
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
本文重点讲解如何搭建App自动化测试框架的思路,而非完整源码。主要内容包括实现目的、框架设计、环境依赖和框架的主要组成部分。适用于初学者,旨在帮助其快速掌握App自动化测试的基本技能。文中详细介绍了从需求分析到技术栈选择,再到具体模块的封装与实现,包括登录、截图、日志、测试报告和邮件服务等。同时提供了运行效果的展示,便于理解和实践。
190 4
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
|
2月前
|
关系型数据库 MySQL Linux
MySQL数据库下载安装教程(Windows&Linux)
本文档详细介绍了MySQL的安装步骤,包括安装前的准备工作、下载安装包、Windows和Linux系统下的具体安装流程,以及如何配置MySQL服务、设置环境变量、启动服务和连接数据库等关键操作。
|
3月前
|
Java 测试技术 Android开发
探索自动化测试的奥秘:从入门到精通
【10月更文挑战第37天】本文将带你进入自动化测试的世界,从基础知识到实战案例,逐步揭示自动化测试的神秘面纱。我们将一起探讨如何利用代码来简化测试过程,提高效率,并确保软件质量。无论你是初学者还是有经验的开发者,这篇文章都能为你提供有价值的见解和技巧。让我们一起踏上这段探索之旅吧!
|
3月前
|
运维 负载均衡 Ubuntu
自动化运维的利器:Ansible入门与实践
【10月更文挑战第31天】在当今快速发展的信息技术时代,高效的运维管理成为企业稳定运行的关键。本文将引导读者了解自动化运维工具Ansible的基础概念、安装步骤、基本使用,以及如何通过实际案例掌握其核心功能,从而提升工作效率和系统稳定性。
|
4月前
|
运维 应用服务中间件 持续交付
自动化运维的利器:Ansible入门与实践
【10月更文挑战第21天】在现代IT基础设施的管理中,自动化运维已成为提升效率、降低错误率的关键。Ansible,作为一种简单而强大的自动化工具,正被广泛应用于配置管理、应用部署和任务自动化等领域。本文将引导你了解Ansible的基本概念,通过实际案例展示如何利用Ansible简化日常运维工作,并探讨其在现代IT运维中的应用价值。无论你是新手还是有经验的系统管理员,这篇文章都将为你开启Ansible的高效之旅提供指导。
|
5月前
|
运维 应用服务中间件 持续交付
自动化运维的利器:Ansible入门与实践
【9月更文挑战第28天】在追求高效、稳定的IT运维时代,自动化工具Ansible凭借其简洁性、易用性和强大的功能脱颖而出。本文旨在通过实际案例引导读者理解Ansible的核心概念和操作流程,并分享如何通过Ansible简化日常运维任务,提升工作效率。从基础安装到高级应用,我们将一步步揭开Ansible的神秘面纱,让初学者也能轻松掌握自动化运维的要诀。

热门文章

最新文章