设备

小米9

效果

autojs1

autojs2

代码

UI


"ui";
const storage = storages.create("dinyue");
auto()var search_value = ''if(storage.contains('search_value')){search_value = storage.get('search_value')
}ui.layout(<vertical padding="30"><text textSize="16sp">输入要匹配的关键字</text><input id="search" text="{{search_value}}"/></vertical>
);//创建新的线程
threads.start(function () {createFloaty();
});/*** 设置悬浮窗*/
function createFloaty() {// const Utils = require('lib')window = floaty.window(<vertical><vertical id="start" bg="#000000" alpha="0.5" w="50" h="52" gravity="center"><img w="30" h="30" layout_gravity="center" src="" /><text text="开始" textColor="white" textSize="10" gravity="center" /></vertical><vertical id="stop" bg="#000000" alpha="0.5" w="50" h="52" gravity="center" marginTop="20"><img w="30" h="30" layout_gravity="center" src="" /><text text="结束" textColor="white" textSize="10" gravity="center" /></vertical>{/* <vertical id="return" bg="#000000" alpha="0.5" w="50" h="52" gravity="center" marginTop="20"><img w="30" h="30" layout_gravity="center" src="" /><text text="返回" textColor="white" textSize="10" gravity="center" /></vertical> */}</vertical>);window1 = floaty.rawWindow(<vertical gravity="bottom"><text id="status" text="运行状态" textColor="white" bg="#00CD66" alpha="0.5"w="*" h="*" gravity="center" /></vertical>);window.exitOnClose();window.setSize(200, 400);window.setPosition(device.width - 1080, device.height/10);window1.exitOnClose();window1.setTouchable(false);window1.setSize(device.width, device.height / 4);window1.setPosition(0, device.height - device.height / 4);//点击返回// window.return.click(() => {//     app.launch("com.xm.duihua");//     engines.myEngine().forceStop();// });//点击停止window.stop.click(() => {// if (thread) {//     thread.interrupt();// }// window1.status.setText("已停止");engines.stopAll()});//点击开始window.start.click(() => {window1.status.setText("正在运行");thread = threads.start(function () {let search_val = ui.search.text()if(search_val.trim().length==0){toast('请填写要匹配的关键字')}else{storage.put('search_value',search_val)engines.execScriptFile("./sub.js",{delay:2000});}});});}

sub.js

const Utils = require('lib');
const storage = storages.create("dinyue");
// 编写主函数:程序启动后执行的逻辑代码。
function main() {sleep(2000)let search =storage.get('search_value')while(!Utils.wait_for_num('互动',1)){back()}sleep(2000)click(535, 2120)sleep(2000)click(945, 1065)sleep(2000)Utils.click_item('已发表内容',[700,0])setText(search)click(995, 1510)sleep(2000)// sleep(3000)// Utils.click_item('【宁大晚安】')while(true){let items = textContains(search).find()if(items.empty()){Utils.swipe_up()}else{for(let index=1;index<items.length;index++){if(items[index].parent().child(0).text().includes('已删除')){continue}items[index].parent().child(1).click()sleep(1000)Utils.click_item('删除',[0,-100])sleep(1000)Utils.click_item('删除',[0,100])}Utils.swipe_up()sleep(1000)}}
}// 启动应用:传入参数依次为:主函数,要启动的 App 名称,当前应用描述,是否语音播报执行状态。
Utils.start_app(main, '订阅号助手', '订阅号助手', false,false)

lib.js

/*** 仓库:https://github.com/kangour/autojs_sdk*/operation_app = ''
window = {width: device.width,height: device.height,
}/*** 权限管理*/
auto.waitFor();
setScreenMetrics(window.width, window.height);
if (!requestScreenCapture()) {log('Screen capture fail');exit();
}/*** 通知栏提示*/
let runing_tip = floaty.rawWindow(<frame gravity="center" bg="#CC999999"><text padding="5 0 5 0" w="auto" h="auto" id="text" textColor='#FFFFFF'></text></frame>
)
runing_tip.setPosition(220, 5);
runing_tip.setTouchable(false);/*** 通知栏提示内容设置* @param {*} _text 提示文本*/
function set_runing_tip(_text) {ui.run(function () {runing_tip.text.setText(operation_app + _text);});
}/*** 修改通知栏提示的坐标* @param {*} _text 提示文本*/
function set_runing_tip_position(x, y) {runing_tip.setPosition(x, y);
}/*** 开始结束提示*/
function start_tip(this_app) {warn('开始执行', this_app)vibrate(100)
}
function end_tip(operation_app) {warn(operation_app, '执行完成')vibrate(300)
}
// 普通上滑解锁
// /**
//  * 解锁
//  */
// function unlock() {
//     while (true) {
//         // 唤醒屏幕
//         if (!device.isScreenOn()) {
//             log('Wake up')
//             device.wakeUp();
//             // 避开锁屏界面的弹窗
//             back()
//         }
//         if (has_text('画报')) {
//             warn('尝试解锁')
//             swipe(500, 1600, 100, 500, 200);
//             sleep(500)
//         } else {
//             warn('解锁成功')
//             break
//         }
//     }
//     log('Unlocked')
//     sleep(800);
//     back() // 避开解锁后界面的弹窗
//     sleep(800)
// }// MUI10 解锁
function unlock() {// 唤醒屏幕if (!device.isScreenOn()) {log('Wake up')device.wakeUp();// 避开锁屏界面的弹窗back()}sleep(800)if (has_text('画报')) {warn('尝试解锁')//下拉状态栏swipe(500, 30, 500, 1000, 300);sleep(400);//点击时间click(100, 120);sleep(400);//解锁 密码 desc(2).findOne().click();desc(3).findOne().click();desc(6).findOne().click();desc(9).findOne().click();//等待解锁完成text('闹钟').waitFor();warn('Unlocked')//返回主页home();}
}/*** 获取文本类型,分别有 text、desc* @param {string} _text 需要查询的文本*/
function get_text_type(_text) {for (i = 5; i > 0; i--) {if (textContains(_text).exists()) {return 'text'} else if (descContains(_text).exists()) {return 'desc'} else {// verbose(_text, '不存在 ' + i)sleep(200)}}return null
}/*** 当前屏幕是否存在文本* @param {*} _text 需要查询的文本*/
function has_text(_text) {set_runing_tip('find ' + _text)point = get_coord_by_text(_text, 'no_tip')if (point != null && point.x > 0 && point.x < window.width && point.y > 0 && point.y < window.height) return truereturn false
}/*** 设备音量* @param {*} number */
function set_volume(number) {device.setMusicVolume(device.getMusicMaxVolume() / 100 * number)
}/*** 震动控制* @param {*} duration 震动时长* @param {*} times 震动次数* @param {*} delay 两次间的延迟*/
function vibrate(duration, times, delay) {if (delay == null) delay = 0if (times == null) times = 1for (i = 0; i < times; i++) {device.vibrate(duration);sleep(delay)}
}/*** 操作失败后的提示弹窗,引导下一步操作* @param {*} callback 弹窗确认后执行的函数,一般出入执行失败的函数* @param {*} _text */
function confirm_continue(callback, _text) {tts_report(_text + '失败')if (get_hours() < 9) {sleep(2000)callback(_text)return}vibrate(1000, 3, 0)if (confirm(_text + "不存在,2s 后重试?")) {toast('2s 后重试')sleep(2000)callback(_text)} else {if (confirm("继续下一步?")) {toast('2s 后继续')sleep(2000)} else {toastLog('手动结束运行')exit()}}
}/*** 文本点击* @param {*} _text 待查询的文本* @param {*} fix_coord 修复坐标位置,传入一个数组,第一位是 x 坐标,第二位是 y 坐标。*                      应用中的页面结构决定了获取的坐标准确性,调试时,可以用开发者工具打开指针位置,查看点击位置是否正确,错误的点击位置则需要传入修复的坐标。*                      例如:[10, -10] 表示在点击时,x 右移 10 个点,y 上移 10 个点* @param {*} tip_type 未找到时,是否需要提示,传入 no_tip 则不提示*/
function click_item(_text, fix_coord, tip_type) {if (fix_coord == undefined) fix_coord = [0, 0]wait_for(_text)log('(click) ' + _text)if (has_text(_text) == false && tip_type != 'no_tip') {confirm_continue(click_item, _text)return}text_type = get_text_type(_text)if (text_type == 'text') {click_text(_text, fix_coord)} else if (text_type == 'desc') {click_desc(_text, fix_coord)} else if (tip_type != 'no_tip') {error('Unknown type', text_type)}
}/*** 任意类型的文本循环点击* @param {*} _text 待查询的文本* @param {*} tip_type 未找到时,是否需要提示,传入 no_tip 则不提示*/
function click_item_each(_text, tip_type) {wait_for(_text)log('(click-each) ' + _text)if (has_text(_text) == false && tip_type != 'no_tip') {confirm_continue(click_item, _text)return}text_type = get_text_type(_text)if (text_type == 'text') {click_text_each(_text)} else if (text_type == 'desc') {click_desc_each(_text)} else if (tip_type != 'no_tip') {error('Unknown type', text_type)}
}/*** 获取文本坐标,文本点击时自动调用* @param {*} _text 待查询的文本* @param {*} tip_type 未找到时,是否需要提示,传入 no_tip 则不提示*/
function get_coord_by_text(_text, tip_type) {text_type = get_text_type(_text)btn = nullif (text_type == null) {if (tip_type != 'no_tip') confirm_continue(get_coord_by_text, _text)return null} else if (text_type == 'text') {btn = textContains(_text).findOne()if (btn.bounds().centerX() == undefined) btn = textStartsWith(_text).findOne()if (btn.bounds().centerX() == undefined) btn = textEndsWith(_text).findOne()} else if (text_type == 'desc') {btn = descContains(_text).findOne()if (btn.bounds().centerX() == undefined) btn = descStartsWith(_text).findOne()if (btn.bounds().centerX() == undefined) btn = descEndsWith(_text).findOne()} else {if (tip_type != 'no_tip') error('Unknown type', text_type)return null}point = btn.bounds()if (point.centerX()) {return {x: point.centerX(),y: point.centerY()}} else {sleep(800)return get_coord_by_text(_text, tip_type)}
}function click_desc(_text, fix_coord) {point = get_coord_by_text(_text)click(point.x + fix_coord[0], point.y + 10 + fix_coord[1]);sleep(800)
}function long_click_desc(_text) {point = get_coord_by_text(_text)log('(long-click)' + _text)press(point.x, point.y + 10, 800)sleep(500)
}function click_desc_each(_text) {let btns = descContains(_text).untilFind();btns.each(function (btn) {let point = btn.bounds();click(point.centerX(), point.centerY() + 10);})sleep(800)
}function click_text(_text, fix_coord) {btn = textContains(_text).findOne()let point = btn.bounds();click(point.centerX() + fix_coord[0], point.centerY() + 10 + fix_coord[1]);sleep(800)
}
function click_text_each(_text) {let btns = textContains(_text).untilFind();btns.each(function (btn) {let point = btn.bounds();click(point.centerX(), point.centerY() + 10);})sleep(800)
}function has_color(_color, x, y, w, h) {return find_color(_color, x, y, w, h)
}function find_color(_color, x, y, w, h) {if (x == undefined) {x = 0y = 0w = device.widthh = device.height}image = captureScreen();let point = findColorInRegion(image, _color, x, y, w, h);if (point) return pointelse {sleep(200)return null}
}
/*** 根据id判断 是否有这个组件* @param {} id * @returns */
function has_id(id_){return id(id_).exists()
}/*** 等待某区域颜色出现,持续 10s* @param {*} _color * @param {*} x * @param {*} y * @param {*} w * @param {*} h */
function wait_for_color(_color, x, y, w, h) {let n = 0while (true) {log('wait_for_color', _color)verbose('(find-color)' + _color)point = find_color(_color, x, y, w, h)if (point) return pointelse {sleep(1000)n++}if (n > 10) {warn('not found', _color)return null}}
}/*** 通过颜色获取坐标* @param {*} _color * @param {*} x * @param {*} y * @param {*} w * @param {*} h */
function get_coord_by_color(_color, x, y, w, h) {verbose('(find-color)' + _color)return wait_for_color(_color, x, y, w, h)
}/*** 0 到 200 s 随机睡眠* @param {*} tip_message 睡眠时的提示消息*/
function random_sleep(tip_message) {if (tip_message == undefined) tip_message = 'random-sleep'random_number = random(0, 200)log(tip_message + ' sleep ' + random_number + ' s')for (i = random_number; i >= 0; i--) {if (i % 3 == 0) toast(tip_message + ' ' + i + ' s')sleep(1000)}
}/*** 按键监听,自动执行,按下音量加结束进程*/
function key_event() {threads.start(function () {events.observeKey();events.on("key_down", function (keyCode, events) {if (keyCode == keys.volume_up) {toastLog('运行结束')exit();}});});
}// /**
//  * 普通左右布局任务
//  * 将即将启动的 App 从最近任务中移除
//  * @param {*} operation_app App 名称
//  */
// function clear_recent(operation_app) {
//     log('移除最近任务')
//     home()
//     sleep(800)
//     recents()
//     sleep(800)
//     let times_swips = 0
//     while (true) {
//         if (has_text(operation_app)) {
//             point = get_coord_by_text(operation_app)
//             if (point.x < 530) {
//                 swipe(100, 1000, 500, 1000, 500);
//             } else if (point.x > 800) {
//                 swipe(500, 1000, 100, 1000, 500);
//             } else {
//                 swipe(point.x - 330, 1400, point.x - 330, 100, 1000);
//                 sleep(500)
//             }
//             times_swips++
//             if (times_swips > 10) {
//                 warn('重试')
//                 times_swips = 0
//                 clear_recent()
//                 break
//             }
//         } else {
//             break
//         }
//     }
//     home()
// }/*** Mui10 任务* 将即将启动的 App 从最近任务中移除* @param {*} operation_app App 名称*/
function clear_recent(operation_app) {log('移除最近任务')home()sleep(800)recents()sleep(800)let times_swips = 0while (true) {if (has_text(operation_app)) {point = get_coord_by_text(operation_app)swipe(point.x, point.y, point.x + 500, point.y, 600);sleep(800)times_swips++if (times_swips > 10) {warn('重试')times_swips = 0clear_recent()break}} else {break}}home()
}
/*** 脚本运行的前置+后置自动化操作,包括屏幕解锁,自动按键监听,移出最近任务,启动 App,执行脚本,结束进程等。* @param {*} callback 启动 App 后需要执行的内容* @param {*} op_app 需要启动的 App,如:网易云音乐* @param {*} this_app 当前脚本描述,如:播放日推* @param {*} use_tts 是否使用结束语音,传入 true 时,会在运行结束前给出语音提示*/
function start_app(callback, op_app, this_app, use_tts, close_app) {if (close_app == undefined) close_app = falsethis_app = this_app != undefined ? this_app : op_appoperation_app = op_app + '\n'while (!device.isScreenOn()) {unlock();}key_event()sleep(800)if (close_app == true) clear_recent(op_app)log('Launch', op_app)launchApp(op_app);start_tip(this_app);sleep(1000)if (op_app) {callback();end_tip(this_app);if (use_tts) tts_report(this_app + '成功')exit()}
}/*** 给出语音提示* @param {*} _text */
function tts_report(_text) {warn(_text)importClass(java.io.File);importClass(android.speech.tts.TextToSpeech);let ttsStatus = false;let ttsListener = new TextToSpeech.OnInitListener({onInit: function (status) {if (status == TextToSpeech.SUCCESS) {let ttsSetLanguageResult = TTS.setLanguage(TTS.getDefaultVoice().getLocale()/*ttsLanguage*/);if (ttsSetLanguageResult != TextToSpeech.LANG_MISSING_DATA && ttsSetLanguageResult != TextToSpeech.LANG_NOT_SUPPORTED) {ttsStatus = true;TTS.stop();speech(_text);// let file = "/sdcard/xxx.mp3";// speech(_text, file);} else {toast("TTS不支持当前语言");}} else {toast("初始化TTS失败");}}})let TTS = new TextToSpeech(context, ttsListener);function speech(ttsText, fileName) {if (TTS && ttsStatus) {if (ttsText.length <= TextToSpeech.getMaxSpeechInputLength()) {if (fileName) {let file = new File(fileName);if (!file.exists()) {file.createNewFile();}TTS.synthesizeToFile(ttsText, null, file, Math.random());} else {TTS.speak(ttsText, TextToSpeech.QUEUE_FLUSH/*QUEUE_FLUSH插队,QUEUE_ADD排队*/, null);}return true;} else {toast("朗读文本过长");return false;}} else {toast("TTS未准备好");return false;}}
}/*** 颜色点击* @param {*} _color 需要点击的颜色* @param {*} x 颜色区域的左上角 x 坐标* @param {*} y 颜色区域的左上角 y 坐标* @param {*} w 颜色区域的宽度* @param {*} h 颜色区域的高度*/
function click_color(_color, x, y, w, h) {let point = get_coord_by_color(_color, x, y, w, h)if (point) {click(point.x, point.y + 20);return true}return false
}/*** 颜色循环点击* @param {*} _color 需要点击的颜色* @param {*} x 颜色区域的左上角 x 坐标* @param {*} y 颜色区域的左上角 y 坐标* @param {*} w 颜色区域的宽度* @param {*} h 颜色区域的高度*/
function click_color_each(_color, x, y, w, h) {let attempts = 0let finded = 0while (true) {if (click_color(_color, x, y, w, h)) {finded++if (finded > 10) return} else {attempts++if (attempts > 2) return}sleep(300)}
}/*** 等待文本出现* @param {*} _text 等待出现的文本*/
function wait_for(_text) {log('(wait)' + _text)let n = 0while (true) {n++if (has_text(_text)) {set_runing_tip('')return true} else {set_runing_tip('查找(' + _text + ')第' + n + '次')}sleep(1500)}
}/*** 等待文本出现 到达某次 跳出循环 默认 20次* @param {*} _text * @param {*} num * @returns */
function wait_for_num(_text,num) {log('(wait)' + _text)if (num == undefined) num = 20let n = 0while (true) {n++if (has_text(_text)) {set_runing_tip('')return true} else {set_runing_tip('查找(' + _text + ')第' + n + '次')if(n>num){return false}}sleep(1500)}
}/*** 接口描述:等待某文本出现之前的点击。* 场景举例:启动网易云音乐时,等待首页出现之前,点击跳过按钮 wait_befor_click('我的', '跳过')* @param {*} wait_text 等待出现的文本* @param {*} click_text 需要点击的文本* @param {*} timer 等待计时器,计时器越长,click_text 被点击的几率越高*/
function wait_befor_click(wait_text, click_text, timer) {log('(wait-click)' + click_text)if (timer == undefined) timer = 10for (let n = timer; n > 0; n--) {if (has_text(wait_text)) {break} else if (has_text(click_text)) {click_item(click_text)} else sleep(600)}// wait_for(wait_text)return
}/*** 获取当前年月日时分秒和星期*/
function get_year() {let now = new Date();return now.getFullYear();
}
function get_month() {let now = new Date();return now.getMonth() + 1;
}
/*** 获取上个月月份*/
function get_last_month() {_month = get_month()if (_month > 1 && _month <= 12) return _month - 1else if (_month == 1) return 12else {error('月份超出范围')return false}
}/*** 计算单休的每月工作时长* @param {*} start_date 开始时间,格式:yyyy/mm/dd* @param {*} end_date * @param {*} rest_days 每周休息天数*/
function count_work_day(start_date, end_date, rest_days) {if (rest_days == undefined) rest_days = 1start_date = string2date(start_date);end_date = string2date(end_date);let delta = (end_date - start_date) / (1000 * 60 * 60 * 24);let weeks = 0;for (i = 0; i < delta; i++) {if (start_date.getDay() < rest_days) weeks++;start_date = start_date.valueOf();start_date += 1000 * 60 * 60 * 24;start_date = new Date(start_date);}return delta - weeks;
}/*** 计算上个月的年份* @param {*} start_date * @param {*} end_date */
function get_last_month_year() {let now = new Date();now = now.valueOf();now -= 20 * 1000 * 60 * 60 * 24;let last_month_date = new Date(now);return last_month_date.getFullYear();
}/*** 返回日期*/
function get_date() {let now = new Date();return now.getDate();
}
/*** 返回星期*/
function get_day() {let now = new Date();return now.getDay();
}
function get_hours() {let now = new Date();return now.getHours();
}
function get_minutes() {let now = new Date();return now.getMinutes();
}
function get_seconds() {let now = new Date();return now.getSeconds();
}/*** 拆分用户设定的时间,20:59:35 分别拆为时分秒* @param {string} _time 时间字符串*/
function get_my_hours(_time) {return Number(_time.split(":")[0])
}
function get_my_minutes(_time) {return Number(_time.split(":")[1])
}
function get_my_seconds(_time) {return Number(_time.split(":")[2])
}/*** 获取倒计时* @param {string} _time 时间字符串*/
function total_seconds_delta(_time) {return ~~(time2date(_time) - new Date()) / 1000
}
function seconds_delta(_time) {let delta_seconds = total_seconds_delta(_time)return parseInt(delta_seconds % 60)
}
function minutes_delta(_time) {let delta_seconds = total_seconds_delta(_time)return parseInt(delta_seconds / 60 % 60)
}
function hours_delta(_time) {let delta_seconds = total_seconds_delta(_time)return parseInt(delta_seconds / 60 / 60 % 60)
}
function time2date(_time) {let str_time = get_year() + '/' + get_month() + '/' + get_date() + ' ' + _timereturn new Date(str_time)
}
function string2date(_time) {return new Date(_time)
}
function time2str(_time) {let total_seconds = total_seconds_delta(_time)let seconds = seconds_delta(_time)let minutes = minutes_delta(_time)let hours = hours_delta(_time)if (total_seconds < 0) {seconds += 59hours += 23minutes += 59}result = ''if (hours != 0) result += hours + 'h 'if (minutes != 0) result += minutes + 'm 'result += seconds + 's'return result
}/*** 简写的日志输出*/
function error() {res = Array.prototype.slice.call(arguments).join(' ')// toast(res)console.error(res)// if (operation_app != '') res = operation_app + resset_runing_tip(res)
}
function warn() {res = Array.prototype.slice.call(arguments).join(' ')toast(res)console.warn(res)// if (operation_app != '') res = operation_app + resset_runing_tip(res)
}
function log() {res = Array.prototype.slice.call(arguments).join(' ')console.log(res)// toast(res)// if (operation_app != '') res = operation_app + resset_runing_tip(res)
}
function verbose() {res = Array.prototype.slice.call(arguments).join(' ')console.verbose(res)// if (operation_app != '') res = operation_app + resset_runing_tip(res)
}/*** 获取问候语*/
function say_hi() {let hour = get_hours()let greet = "Hi"if (hour <= 3) {greet = "晚安"} else if (hour < 9) {greet = "早上好"} else if (hour < 12) {greet = "上午好"} else if (hour < 14) {greet = "中午好"} else if (hour < 18) {greet = "下午好"} else if (hour < 24) {greet = "晚上好"}return greet
}function click_id(id_name) {id(id_name).findOne().click()
}function swipe_down() {swipe(500, 500, 500, 1500, 500)sleep(800)
}function swipe_up() {swipe(500, 1500, 500, 100, 500)sleep(800)
}/*** 提醒用户,接下来的操作需要注意(用户确认后,方可继续)* @param {*} _text */
function be_careful(_text) {log('请注意,', _text)while (true) {if (confirm(_text)) break;else sleep(1000);}sleep(1000);
}/*** 提醒用户,接下来的操作需要人工处理(用户确认后,方可继续)* @param {*} _text */
function handwork(_text, timer) {timer = timer === undefined ? 2 : timerlet timer_backup = timerlog('人工', _text)while (true) {for (timer; timer > 0; timer--) {sleep(1000);toast('倒计时 ' + timer + ' s');}if (confirm(_text + '?')) break;else timer = timer_backup + 1}
}
/*** 倒计时 秒后执行* @param {}} timer */
function countDown(timer){timer = timer === undefined ? 2 : timerfor (timer; timer > 0; timer--) {toast('倒计时 ' + timer + ' s 后执行');sleep(1000);}
}module.exports = {swipe_up: swipe_up,handwork: handwork,be_careful: be_careful,swipe_down: swipe_down,unlock: unlock, // 解锁clear_recent: clear_recent, // 结束最近任务start_app: start_app, // 脚本运行的前置+后置自动化操作,包括屏幕解锁,自动按键监听,移出最近任务,启动 App,执行脚本,结束进程等。wait_for: wait_for, // 等待文本出现wait_for_num:wait_for_num,//等待文本出现 n次has_text: has_text, // 当前屏幕是否存在文本vibrate: vibrate, // 设备震动say_hi: say_hi, // 获取问候语log: log, // 普通日志warn: warn, // 警告日志error: error, // 错误日志verbose: verbose, // 调试日志time2str: time2str, // 时间转字符串time2date: time2date, // 时间转日期random_sleep: random_sleep, // 0 到 200 s 随机睡眠total_seconds_delta: total_seconds_delta, // 获取倒计时click_item: click_item, // 任意类型的文本点击click_color: click_color, // 颜色点击click_id: click_id,find_color: find_color,has_color: has_color,wait_for_color: wait_for_color,click_item_each: click_item_each, // 任意类型的文本循环点击click_color_each: click_color_each, // 颜色循环点击wait_befor_click: wait_befor_click, // 接口描述:等待某文本出现之前的点击。 场景举例:启动网易云音乐时,等待首页出现之前,点击跳过按钮 wait_befor_click('我的', '跳过')get_coord_by_color: get_coord_by_color, // 通过颜色获取坐标get_coord_by_text: get_coord_by_text, // 获取文本坐标,文本点击时自动调用get_last_month: get_last_month, // 获取上个月月份get_year: get_year, // 获取年份get_month: get_month, // 获取月份get_date: get_date, // 返回日期get_day: get_day, // 返回星期get_hours: get_hours, // 返回小时get_minutes: get_minutes, // 返回分钟get_seconds: get_seconds, // 返回秒set_volume: set_volume, // 设置设备音量set_runing_tip: set_runing_tip, // 通知栏提示内容设置key_event: key_event, // 音量加结束脚本string2date: string2date, // 字符串转日期get_last_month_year: get_last_month_year, // 获取上个月的年份count_work_day: count_work_day, // 获取工作天数set_runing_tip_position: set_runing_tip_position, // 设置状态栏位置has_id:has_id,//根据id 判断是否有这个组件countDown:countDown,//倒计时
}

网站

Auto.js Pro Docs

Autojs自动化 实现自动删除公众号文章(通过订阅号助手删除)相关推荐

  1. 如何将微信服务号改成订阅号?

    微信服务号是不能转成订阅号的,但是可通过迁移来完成. 操作流程如下 所需资料:单位证件照片,管理员身份信息及联系方式: 迁移要求:公众号的主管理员能扫码,单位能盖章(个体户无需盖章): 所需时间:全程 ...

  2. QQ邮件列表:自动定时发送最新文章到订阅者的邮箱

    原文地址:https://www.cmhello.com/list-qq-com.html 其实这是2010年的老文章,当时QQ邮件列表还在内测,经过两年的发展,QQ邮件列表已经成熟多了,之前的教程也 ...

  3. 微信公众平台开发之订阅号申请,接口验证篇

    2019独角兽企业重金招聘Python工程师标准>>> 1,运营主体选择 微博公众平台的账号目前分为两类,一是服务号,另外一种是订阅号,分析我网站的需求(每天给粉丝推送美食信息,回复 ...

  4. 微信公众号开发之订阅号如何获取用户信息(一)

    最近在做微信的公众号的开发.之前是在一个认证过的微信服务号上开发一些相应的功能. 比如说 对认证过的微信服务好进行 自定义菜单的开发,模板消息的回复以及关键词回复的功能. 但是目前新接了这样一个需求: ...

  5. 小白如何开通微信公众号中的订阅号(服务号)以及认证账号

    搞清楚微信公众订阅号.服务号的区别 首先要告诉大家的是,定位和用途的不同是区别的本质.微信公众平台是个平台,提供给运营者,而运营者通过这样一个平台大家微信公众号为微信用户提供资讯和服务.看到了么,咨询 ...

  6. 订阅号如何配置服务器信息,订阅号服务号区别和订阅号启动服务器配置

    1.微信公众号订阅号服务号区别 参考官网介绍和微信订阅号和服务号的区别是什么 2.订阅号启动服务器配置方法 2.1基本配置 点击左册下拉菜单,有一个"基本配置",进入基本配置可以看 ...

  7. php订阅号怎么借服务号权限,微信订阅号已经认证能否有网页授权功能

    微信订阅号已经经过认证了,能否有网页授权获取用户信息的权限,应该怎么做网页授权的功能? 各位高人给个指点 本人微信开发的菜鸟呀,很多都不懂~ 解决方案 10 1.设置域名 2.自定义菜单链接特殊处理( ...

  8. SVG排版公众号文章『视频号卡片定位和隐藏』模板代码

    模板效果 模板代码 <section style="background-color: #000;margin: 0 auto;"><!-- 葡萄酒视频号内容 - ...

  9. 【微信公众号】个人订阅号开发模式下自定义菜单

    点开开发模式,原菜单一定失效了. 点击微信公众平台,左侧添加功能插件 点击自定义菜单 点击开启

最新文章

  1. 记录一下水下相机标定
  2. JVM-12虚拟机性能监控与故障处理工具之【JDK的可视化工具-VisualVM】
  3. linux提取字符串特定结果
  4. 「干货总结」程序员必知必会的十大排序算法
  5. .net中自定义过滤器对Response内容进行处理
  6. CH - 6803 导弹防御塔(二分图最大匹配-多重匹配(拆点法))
  7. cad lisp 二次抛物线_学习CAD的五个段位,你是青铜还是王者?
  8. Luogu 3267 [JLOI2016/SHOI2016]侦察守卫
  9. postgresql 计算时间差的秒数、天数
  10. 三星note3 android4.3,三星N9002 (Note3联通双卡版 Android4.3)一键救砖教程,轻松刷回官方系统...
  11. Android 布局管理器 之 TableLayout
  12. init_MUTEX被废除
  13. wordpress上传文件报错的解决方法(413 Request Entity Too Large、超过upload_max_filesize文件中定义的php.ini值)
  14. bzoj 1930: [Shoi2003]pacman 吃豆豆 [费用流]
  15. Off World Live 插件:广播UE4内部的音频信号到NDI
  16. AutoCAD2022下载安装教程
  17. svg格鲁特动画代码
  18. 微信网络营销 你造吗?
  19. WEB浏览器视频流播放方案
  20. 周志明:《凤凰架构:构建可靠的大型分布式系统》

热门文章

  1. C++中 public,protected, private 访问标号小结
  2. Rocksdb 利用recycle_log_file_num 重用wal-log文件
  3. Go 分布式学习利器(19)-- Go并发编程 之 CSP(communicating sequential processes) 机制
  4. 贪心:Jump Game 跳跃游戏
  5. C++ 函数参数 值传递与引用传递
  6. swift - idfa(唯一标示/下载量/广告追踪)
  7. 嵌入式linux学习笔记1—内存管理MMU之虚拟地址到物理地址的转化
  8. .net erp(办公oa)开发平台架构之流程服务概要介绍
  9. 02_计算机科学和软件工程的区别
  10. [linux内核][linux中断]——软中断机制