Logo

Home Assistant中的Scheduler组件:基于时间控制设备的强大工具

scheduler-component

简介

Scheduler组件是Home Assistant(简称HA)的一个自定义组件,专门用于基于时间控制现有设备。它可以与Lovelace scheduler卡片完美配合使用,为用户提供了一个强大而灵活的调度系统。

Scheduler组件的核心功能是创建调度器实体。每个调度器实体都定义了在特定时间执行的操作,例如"每天21:00打开我的台灯"。HA中的任何实体都可以用来创建调度器实体,并且可以使用HA中可用的任何服务。

Scheduler组件示例

安装过程

安装Scheduler组件的过程分为以下几个步骤:

  1. 下载文件
  2. 重启Home Assistant
  3. 将集成添加到Home Assistant
  4. 添加scheduler-card(可选)

下载文件

有两种方法可以下载Scheduler组件的文件:

方法一:通过HACS安装

  1. 确保已经安装了HACS。如果没有,可以在HA中运行wget -O - https://get.hacs.xyz | bash -来安装。
  2. 在HACS中选择"Integrations"。
  3. 点击页面底部的"+"按钮。
  4. 搜索"scheduler component"。
  5. 选择它并在HACS中点击安装。

方法二:手动安装

  1. 克隆Scheduler组件的GitHub仓库或下载源代码的zip文件。
  2. custom_components/文件夹及其内容添加/合并到你的HA配置目录中。

重启Home Assistant

为了让新添加的集成加载,需要重启Home Assistant。

将集成添加到Home Assistant

这是很多人容易忽略的一步:

  1. 在HA中,进入Configuration > Integrations。
  2. 在右下角,点击带有"+"的大按钮。
  3. 如果组件安装正确,你应该能在列表中找到"Scheduler"。(可能需要清除浏览器缓存才能显示)
  4. 选择它,Scheduler集成就可以使用了。

添加scheduler-card(可选)

按照Lovelace scheduler card的说明设置卡片,这样就可以配置调度器实体了。

更新和卸载

更新过程

  1. 更新文件:
    • 使用HACS:在HACS面板中,当有新版本可用时会出现通知。按照HACS中的说明更新安装文件。
    • 手动更新:下载最新版本的zip文件,解压到HA安装目录的custom_components文件夹中,覆盖之前的安装。
  2. 重启HA以加载更改。

要查看已安装的版本:在HA中,转到Configuration -> Integrations。在Scheduler集成卡片中,你应该看到一个"1 device"的链接,点击它。在表格中点击"Scheduler"设备,你就能看到设备信息。"firmware version"代表已安装的版本号。

卸载过程

  1. 从HA中移除Scheduler:在HA中转到Configuration -> Integrations。找到Scheduler集成的卡片,点击三个点的按钮,然后点击"Delete"。
  2. 删除文件:
    • 如果是通过HACS安装的:在HACS面板中找到Scheduler组件,点击三个点的按钮,然后点击"Uninstall"。
    • 如果是手动安装的:在custom_components目录中,删除"scheduler"文件夹。
  3. 重启HA,使组件的所有痕迹消失。

备份

调度配置存储在HA配置目录的.storage文件夹中,文件名为scheduler.storage

如果通过HA supervisor创建快照,这个文件应该会自动备份。否则,请确保将此文件包含在你的备份中。

HA中的实体是在(重新)启动HA时从scheduler.storage文件创建的。

Scheduler实体

实体ID

Scheduler集成的实体ID遵循switch.schedule_<token>的模式,其中<token>是随机生成的6位数字代码。

你可以像对待其他HA中的switch实体一样处理这些实体,这意味着你可以将它们放在任何Lovelace卡片中以便快速访问。

状态

Scheduler实体可以有以下状态:

状态描述
off调度已禁用。禁用的调度不会跟踪时间,也不会执行任何操作。
on调度内部计时器正在运行,等待计时器到期。属性next_trigger提供了到期的时刻。
triggered计时器已完成,操作已执行。实体将等待1分钟,然后重置计时器。
unknown出现问题,调度未运行。

服务

由于调度遵循switch平台,你可以使用switch.turn_onswitch.turn_off服务来启用和禁用调度。

此外,还有以下可用服务:

scheduler.add

添加新的调度器实体。

字段类型可选/必需描述备注
weekdays列表可选应执行调度的日期(星期几)有效值为:mon, tue, wed, thu, fri, sat, sun, daily, workday, weekend。默认为daily
start_date日期可选调度应开始触发的起始日期有效格式为yyyy-mm-dd
end_date日期可选调度应触发的最后日期有效格式为yyyy-mm-dd。如果end_date已过,调度将不再触发。
timeslots列表必需应执行的时间/时间间隔列表以及相应的操作更多信息请参见时间段
repeat_type字符串可选控制触发后的重复行为有效值为:repeat(默认值,触发后循环), single(触发后删除自身), pause(触发后关闭,可通过打开重置)。
name字符串可选调度实体的友好名称该名称也将用于调度的entity_id。默认值为Schedule #abcdef,其中abcdef为随机生成的序列。

scheduler.edit

更新现有调度器实体的配置。覆盖旧值。

服务参数与scheduler.add相同,只是需要提供要修改的调度的entity_id

注意,只需提供要更改的参数,如果未提供参数,将保留先前的值。

scheduler.remove

删除调度器实体。

字段类型可选/必需描述备注
entity_id字符串必需调度器实体的实体ID例如:switch.schedule_123456

scheduler.copy

复制调度器实体。

字段类型可选/必需描述备注
entity_id字符串必需现有调度器实体的实体ID例如:switch.schedule_123456
name字符串可选创建的调度实体的友好名称该名称也将用于调度的entity_id。默认值为Schedule #abcdef,其中abcdef为随机生成的序列。

scheduler.run_action

手动触发调度。

字段类型可选/必需描述备注
entity_id字符串必需调度器实体的实体ID例如:switch.schedule_123456
time字符串可选触发调度的时间如果调度只有一个时间段,将始终触发该时间段。对于有多个时间段的调度:如果未提供时间:将触发与当前时间(现在)重叠的调度。如果提供了时间:将触发与提供的时间重叠的调度。
skip_conditions布尔值可选是否应跳过调度的条件

数据格式

时间段

时间段定义了调度触发的时间点,以及需要执行的操作。还可以选择指定在执行操作之前需要验证的条件。

名称类型可选/必需描述备注
start字符串必需调度应触发的时间(24小时格式)应在00:00-23:59范围内。每个时间段应有唯一值。输入也可以相对于太阳:例如sunrise+01:00sunset-00:00
stop字符串可选时间段结束的时间(24小时格式)仅在定义时间段时需要。应在00:01-00:00(第二天开始)范围内。stop时间必须至少在start时间后一分钟。
conditions列表可选执行操作前应验证的条件更多信息请参见条件
condition_type字符串可选验证多个条件时应用的逻辑有效值为:and(所有条件都必须满足), or(必须满足一个或多个条件)。
track_conditions布尔值可选观察条件实体的变化,一旦条件变为有效就重复操作
actions列表必需达到start时间时要执行的操作更多信息请参见操作

注意:

为了保证与scheduler-card的兼容性,需要满足以下条件:

  1. 调度必须由以下之一组成:

    • 只有start时间的单个时间段
    • 一个时间段列表,所有时间段都有startstop时间,它们不重叠且不相对于太阳。
  2. 所有时间段的条件必须相同。

  3. 操作列表只能包含单个服务/service_data组合(多个操作只能有不同的entity_id)。

条件

条件用于定义在执行预定操作之前需要验证的规则。目前条件仅限于检查实体的状态。

名称类型可选/必需描述备注
entity_id字符串必需条件适用的实体例如:binary_sensor.my_window
value字符串必需与实体状态比较的值例如:on
match_type字符串必需比较应用的逻辑有效值为:is(实体状态必须匹配value), not(实体状态不得匹配value), below(实体状态必须低于value,仅适用于数值), above(实体状态必须高于value,仅适用于数值)。

操作

操作是HA服务与entity_id的组合。有关可用操作和有效参数的信息,请参见HA中的Developer Tools -> Services。

名称类型可选/必需描述备注
entity_id字符串必需需要执行操作的实体例如:light.my_lamp
service字符串必需需要在实体上执行的HA服务例如:light.turn_on
service_data字典可选在服务调用中使用的额外参数例如:{brightness: 200}

结语

Scheduler组件为Home Assistant用户提供了一个强大而灵活

最新项目

Project Cover
豆包MarsCode
豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。
Project Cover
AI写歌
Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。
Project Cover
商汤小浣熊
小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。
Project Cover
有言AI
有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。
Project Cover
Kimi
Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。
Project Cover
吐司
探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。
Project Cover
SubCat字幕猫
SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。
Project Cover
AIWritePaper论文写作
AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。
Project Cover
稿定AI
稿定设计 是一个多功能的在线设计和创意平台,提供广泛的设计工具和资源,以满足不同用户的需求。从专业的图形设计师到普通用户,无论是进行图片处理、智能抠图、H5页面制作还是视频剪辑,稿定设计都能提供简单、高效的解决方案。该平台以其用户友好的界面和强大的功能集合,帮助用户轻松实现创意设计。
投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号