京公网安备 11010802034615号
经营许可证编号:京B2-20210330
作者:星安果
来源:AirPython
大家好,我是安果!
最近发现一款神器「 Hamibot 」,它是一款 Android 端的自动化工具,它基于 AutoJS 源码进行的二次开发
官方网站:https://docs.hamibot.com/
Hamibot 脚本市场提供了很多脚本,我们都可以免费导入进行试用
首先,我们在 PC Web 的控制台添加一个机器人,然后使用手机通过「 配对码 」进行配对,接着从脚本市场选择一个功能脚本导入,最后在控制台运行脚本就可以在手机上运行一系列自动化操作了
当然,我们也可以根据官方文档编写一些实用的脚本上传到平台上,获取一些佣金提成
由于 Hamibot 基于 AutoJS,语法都大同小异,所以本篇文章将只介绍 Hamibot 一些实用的使用技能
2-1 App 保活在线
自动化脚本运行实际上是 App 接受到 Web 端 Hamibot 控制台发送的指令,进而驱动手机进行的一系列动作,所以保证 Hamibot App 在后台一直运行变得非常重要
程序保活主要包含 6 个方面,分别是:
2-2 启动应用
Hamibot 中的 app 模块提供了很多函数用于操作 App 应用
其中,启动一个应用有 3 种方式
# 启动应用的3种方式
# 方式一:通过应用的名称
# 比如:某宝、某多、某条
app.launchApp('某宝');
# 方式二:通过应用的包名
# 包名通过adb命令或者Android Studio 去解析 APK 获取
# 比如:启动 Hamibot 应用
app.launch('com.hamibot.hamibot');
# 方式三:与第二种类似,全局函数
# 通过应用包名启动应用
launchPackage('com.hamibot.hamibot');
2-3 触摸操作
触摸操作是基于屏幕坐标进行点击、长按、滑动等操作,但是该操作需要 Android 7.0 以上或 Root 权限才能有效
PS:对于一些基于元素的点击操作失效的场景,换成触摸操作反而能很好的解决问题
// 使用触摸操作点击某个元素
// 获取某个元素
var widget = id('xxx').findOne();
// 获取其中心位置,执行点击操作
click(widget.bounds().centerX(), widget.bounds().centerY());
2-4 控件操作
控件操作为编写脚本的核心内容,AutoJS 和 Hamibot 官方文档都非常的详细地列出了 UiSelector、UiObject、UiCollection 的使用方法
官方文档:
https://docs.hamibot.com/reference/widgetsBasedAutomation/
2-5 网络请求
结合网络请求,能将爬虫与自动化完美地结合在一起
这里以常见的 GET、POST 请求为例
// 1-GET请求
// 网络请求,获取响应值
var r = http.get('www.baidu.com');
// 响应码
log('code = ' + r.statusCode);
// 响应体(字符串)
log('html = ' + r.body.string());
// 2-POST 请求
var url = 'http://www.**.com/api/login';
//直接传入一个字典作为参数
r = http.postJson(url, {
username: 'xag',
password: '123456'
});
//获取请求的响应并弹出吐司
toastLog(r.body.string());
官网提供了网络请求的基础函数,大家可以自行去扩展使用
2-6 线程
脚本默认是在主线程中运行的,我们可以将一些耗时的操作添加到线程中执行
auto.waitFor();
//开启一个子线程
threads.start(function() {
//在新线程执行的代码
while (true) {
log('子线程');
}
});
//主线程
while (true) {
log('脚本主线程');
}
在实际使用 Hamibot 的过程中,发现其提供的定时任务没有 AutoJS 使用起来方便
比如,如果我想固定在每一天的某个时间执行某个脚本,可惜的是,官方提供的任务功能没有实现
这时候,我们就需要我们在代码中自己去实现这个功能点了
function setScheduledTask(hour, minute, callTask) {
let taskTime = new Date();
taskTime.setHours(hour);
taskTime.setMinutes(minute);
let timeDiff = taskTime.getTime() - (new Date()).getTime(); // 获取时间差
timeDiff = timeDiff > 0 ? timeDiff : (timeDiff + 24 * 60 * 60 * 1000);
setTimeout(function() {
callTask();
setInterval(callTask, 24 * 60 * 60 * 1000); // 24小时为循环周期
}, timeDiff);
}
//获取配置文件中设置的时间(小时、分钟)
const { hour,minute } = hamibot.env;
toastLog(hour);
toastLog(minute)
function
create_thread_and_do_something(){
//定义子线程
var my_thread = threads.start(function(){
console.log("开始执行子线程。 。。。")
...
console.log("结束执行子线程。。。。")
})
}
// 每天某个时间开启一个子线程,执行一个任务
setScheduledTask(hour, minute,
create_thread_and_do_something);
上面内容列出了使用 Hamibot 编写自动化脚本需要掌握的一些功能点
Hamibot 和 AutoJS 的脚本语法基本类似,但是 Hamibot 在易用性、稳定性、群控方面更有优势一点,更多复杂的功能大家可以自行去查阅官方文档去拓展
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在 MySQL 查询性能优化体系中,索引是降低查询耗时、提升数据库吞吐的核心手段。其中联合索引与覆盖索引是实际开发中最高频的两 ...
2026-06-15在数据仓库建设与商业智能分析体系中,维度建模是应用最广泛的建模方法论,而事实表与维度表是维度建模的两大核心构件,共同构成 ...
2026-06-15 很多数据分析师能熟练计算指标,但当被问到“这家企业的核心业务目标是什么”“如何把模糊的战略目标拆解为可量化的指标”“ ...
2026-06-15在数据分析、业务监控、运营复盘等场景中,列值趋势计算是核心需求之一。无论是分析销售额的月度增长、用户活跃的变化趋势、库存 ...
2026-06-12在数字经济深度渗透的当下,消费者的购买行为已从过去的 “被动接受” 转变为 “主动决策”。流量红利消退、获客成本攀升、用户 ...
2026-06-12CDA三级认证是三个级别中的塔尖,全面考察数据战略、团队领导和复杂项目的综合能力。它所对应的《敏捷数据挖掘》教材,不再局限 ...
2026-06-12在游戏产业的商业逻辑中,付费玩家是支撑游戏生存与发展的核心支柱。行业普遍遵循 “二八定律”:20% 的付费玩家贡献了游戏 80% ...
2026-06-11【核心关键词】企业、定位、传统、产品、互联网、可视化、业务侧、数字化、结构化、数据分析、传统制造业、市场状态、发展空间 ...
2026-06-11 解读《CDA二级教材:量化策略分析(2025)》的全景结构与学习逻辑 ” CDA二级认证是企业招聘数据分析师时最常提及的证书门槛 ...
2026-06-11【核心关键词】药企、可视化、营销、分类、数据分析师、销售数据、业务人员、指导方向、分析报告、营销数据、营销医生 【专访摘 ...
2026-06-10在统计学分析、问卷调研、实验验证、业务复盘等场景中,卡方检验与 T 检验是应用最广泛的两类基础假设检验方法。前者专门处理分 ...
2026-06-10 很多数据分析师每天都在计算指标、制作报表,但当被问到“什么叫指标数据元”“指标数据标准包含哪些核心维度”“指标数据质 ...
2026-06-10在MySQL数据库日常查询、数据统计、后台接口开发、数据导出等场景中,开发者经常需要查询数据表除某几列之外的所有字段。例如查 ...
2026-06-09在Python网络请求、爬虫开发、接口测试、数据抓取等实操场景中,requests库是最常用的第三方请求工具,而content属性是requests ...
2026-06-09 数据分析正在重塑每一个行业。CDA认证的三本官方教材,分别对应Level I、Level II、Level III,为你铺就从业务数据分析到数 ...
2026-06-09在数字财务、智慧财税、业财融合深度推进的当下,传统财务模式下数据标准混乱、业务流程碎片化、知识无法沉淀、系统互通性差等问 ...
2026-06-08随着数字经济深度渗透各行各业,数据正式成为继土地、劳动力、资本、技术之后的第五大生产要素,是企业数字化转型、精细化运营、 ...
2026-06-08 很多数据分析师能熟练写SQL、做透视表,但当被问到“数据是从哪里来的?经过哪些加工才进入数据仓库?ETL具体做了什么?”时 ...
2026-06-08【核心关键词】贷款、报表、课程、专业、建模、缺失值、营销、互联网、银行、办公自动化、数据分析、数据预处理、特征工程、贷 ...
2026-06-05在数据库数据查询、业务报表统计、多表关联分析中,LEFT JOIN左连接是使用率最高的SQL关联查询语句。其核心特性是保留左表全部数 ...
2026-06-05