用Python写一个蛋仔派对自动弹琴脚本

2023-12-16 23:10

本文主要是介绍用Python写一个蛋仔派对自动弹琴脚本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

如何用Python写一个自动弹琴脚本

引言(何从缘起):本身想写一个华为平板的主题来的在小妹前面耍酷,但是翻阅官方文档的时候却犯了难,有种12岁但是却力不从心的赶脚,这官方文档翻起来一本书厚啊有没有搞错!想要无伤一个下午就写出来显然是国足踢进世界杯——天方夜谭,所以既来之则安之借此契机不如就接触一下写脚本把,用脚本还可以定时抢券,秒换名刀复活甲,主打一个赋能吃喝玩乐,总之有好果子吃。。。

项目:实现蛋仔派对自动弹琴

‘脚本入手’吧,于是就有了用“一触即发写(json)脚本的想法”

首先什么是json?:JSON(JavaScript Object Notation,JS对象简谱)是一种轻量级的数据交换格式,它基于ECMAScript(欧洲计算机协会制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得JSON成为理想的数据交换语言,易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。

(一)一触即发APP

点击此处下载一触即发APP

从点击事件的脚本入手

1. 要做一个游戏弹琴的脚本,其实就两件事。 要点击哪里and以及何时点击
2. 我们先打开一触即发APP,可以看见一触即发可以实现的功能有很多,我们主要看榜上有名的点击操作
3.之后把脚本文件传到电脑上(用微信把文件发送到电脑上就ok辣)或者保守一点可以用USB线连接手机和电脑,之后手机上选择文件传输模式,之后找到”yichujifa“这个名字的文件夹再把文件复制过来也可以,都是一样的
4.之后记事本的格式打开下面的一个脚本文件

5.打开后的格式如下??

大概能猜到data部分里面是我们要操作修改的数据

(二)写一个java程序,翻译data标签中的json代码

1.java程序进行URL的编码和解码

import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;//解码
import java.net.URLEncoder;//编码
public class 一触即发URL转换 {public static void main(String[] args) {try{
//str1脚本的URL源码String str1="";System.out.println(URLDecoder.decode(str1,"utf-8"));
​
​//str2输入编程后的文件编码到URL格式String str2= "";System.out.println(URLEncoder.encode(str2,"utf-8"));
​
​}catch (UnsupportedEncodingException e){e.printStackTrace();}
​}
}

2.随机解码一个文件(就拿APP内自带的辉月脚本里面的data部分解码作为示例吧)

{"actions":
[
{"actionType":2,"witeTime":"20","param":{"count":"1","desc":"点击商店","x":"2213","y":"50"}},
{"actionType":2,"witeTime":"20","param":{"count":"1","desc":"选中装备栏末位","x":"1013","y":"938"}},
{"actionType":2,"witeTime":"20","param":{"count":"1","desc":"出售装备","x":"2030","y":"871"}},
{"actionType":2,"witeTime":"20","param":{"count":"1","desc":"点击套装","x":"345","y":"422"}},
{"actionType":2,"witeTime":"20","param":{"count":"1","desc":"选中辉月","x":"778","y":"466"}},
{"actionType":2,"witeTime":"20","param":{"count":"1","desc":"购买","x":"1966","y":"961"}},
{"actionType":2,"witeTime":"50","param":{"count":"1","desc":"辉月启动","x":"2150","y":"450"}},
{"actionType":2,"witeTime":"25","param":{"count":"1","desc":"退出","x":"2065","y":"113"}}
],
"variables":[],"scale_width":1080,"scale_height":2412}
​
【一】说明:上面的内容是根据URL解码得到的,可以分析出上面是一个字典与列表镶嵌的数据类型
【二】这几个对象 :
结构概况:{"actionType":##, "witeTime":"##", "param":{"count":"##",}
​
【actionType是操作方式】:2---"点击"操作
【witetime是等待时常】:20---等待20毫秒后进行下一步操作
【param是程序体】:①count---运行的次数②desc---描述③x,y---表示操作位置的横纵坐标
​

(三)写一个Python程序批量生成点击操作(之前计算机二级选学了Python)

import json
'''【功能】:对简谱文件批量处理成格式文件
【认识简谱】:了解高音中音低音都是长得什么样的,再看拍子,常见的音符要弄懂。。
【乐谱TXT书写规则】(简谱yuepu)+','+(演奏持续时长yanzoutime)
高音用两个相同的1-7的数字表示,低音用三个,中音用一个,空音符用0表示,z等同于一个八分音符,
例如:3,f,              【中音3一拍,高音2半拍,低音1四分之一拍,间隔四拍不做任何操作】22,f/2,111,f/4,0,4z,【具体功能】:把简谱文件大致分为两部分,第一部分是对应的简谱,第二部分是演奏持续时长
'''
lt_yuepu=[]      #列表,文件乐谱部分
lt_yanzoutime=[] #列表,文件演奏时长部分
每分钟节拍数=180    #in other words也就是每分钟的八分音符个数
单位拍时间=60000//每分钟节拍数
​
with open('无敌.txt', 'r',encoding='utf-8') as file:data = file.read()  # 读取整个文件data = data.replace('\n', '')#删除文本每行的换行符#print(data)#打印出文本list_data=data.split(',')#调用字符串split方法,原理是根据‘,’划分,若分隔符后面没有有效字符了,那就会多一个空字符串‘’元素。所以此时的字符串多了一个元素list_right=list_data[:-1]#list_right表示的是正确的简谱文件列表格式#打印出简谱文件的所有音谱及时长数据print(list_right)
​
​
n=0
#乐谱切分为两部分
for i in list_right:if n%2==0:lt_yuepu.append(i)#乐谱列表else:lt_yanzoutime.append(i)#演奏时长列表n+=1
# print('简谱列表:',lt_yuepu)
# print('演奏时长列表:',lt_yanzoutime)
print('操作数量',len(lt_yuepu))
​
​
def yposition (yp):#yp是yuepositionif yp == '11':return 403,1063if yp == '22': return 668,1056if yp == '33': return 937,1054if yp == '44': return 1207,1050if yp == '55': return 1477,1057if yp == '66': return 1746,1056if yp == '77': return 2015,1048if yp == '1': return 550,1258if yp == '2': return 815,1255if yp == '3': return 1083,1250if yp == '4': return 1354,1256if yp == '5': return 1618,1254if yp == '6': return 1896,1249if yp == '7': return 2160,1255if yp == '111': return 413,1460if yp == '222': return 671,1461if yp == '333': return 941,1455if yp == '444': return 1205,1459if yp == '555': return 1481,1462if yp == '666': return 1747,1461if yp == '777': return 2004,1462if yp=='0':return 1,1
​
#根据音谱得到x,y的坐标
​
​
def ytime(ytim):if ytim=='f':return 单位拍时间if ytim == '2f': return str(int(2*单位拍时间))if ytim == '4f': return str(int(4*单位拍时间))if ytim == 'f/2': return str(int(0.5*单位拍时间))if ytim == 'f/4': return str(int(0.25*单位拍时间))if ytim =='3/2f':return  str(int(1.5*单位拍时间))if ytim == '7/2f': return str(int(2.5 * 单位拍时间))if ytim=='z':return  str(int(单位拍时间))if ytim=='z/2':return  str(int(0.5*单位拍时间))if ytim == 'z/4': return str(int(0.25*单位拍时间))if ytim == '2z': return str(int(2*单位拍时间))if ytim == '4z': return str(int(4*单位拍时间))if ytim=='5/2f':return  str(int(2.5*单位拍时间))if ytim == '5/2f': return str(int(2.5 * 单位拍时间))if ytim == '9/2f': return str(int(4.5 * 单位拍时间))if ytim == '3f': return str(int(3 * 单位拍时间))if ytim == '3/2z': return str(int(1.5 * 单位拍时间))if ytim == '13/8f': return str(int( 1.625* 单位拍时间))
​
#根据时长计算出时间
​
#用for循环打印输出脚本格式内容
str_front='{"actions":['#开头的固定格式
print(str_front,end='')
​
str_back='],"variables":[]}'#结尾的格式
​
for i,j in zip(lt_yuepu,lt_yanzoutime):x_jp,y_jp=yposition(i)yt=ytime(j)x_value = str(x_jp)  # 替换x后面的值y_value = str(y_jp) # 替换y后面的值witeTime_value=yt#替换witeTime后面的值
​
​json_str = '{"actionType":2,"witeTime":"20","param":{"count":"1","desc":"点击商店","x":"2213","y":"50"}}'json_obj = json.loads(json_str)
​json_obj['param']['x'] = x_valuejson_obj['param']['y'] = y_valuejson_obj['param']['desc']='0'json_obj['witeTime'] =str(yt)
​
​new_json_str = json.dumps(json_obj)#print(new_json_str+',',end='')s=new_json_str.replace(' ','')print(s+',',end='')#按格式规则打印中间内容
​
print(str_back)#打印结尾格式

(四)把Python代码编码成URL格式:

  1. Python程序成功运行后复制输出结果

  2. 打开第二步之前我们写的java代码

  3. 把内容复制到String str2里面进行encode编码操作

  4. 运行程序,查看运行输出的结尾是否为%7D

  5. 如果结尾不是%7D则删除后面多余的部分确保结尾是%7D

  6. 打开我们第一步从手机传到电脑上的一触即发脚本文件

  7. 用记事本的格式打开文件,把《data》《/data》之间的内容删除

  8. 粘贴到《data》《/data》之间来替换源文件,再次检查末尾是否是%7D,如果是则保存发送到手机脚本做成,不是则删除后面多余的部分直到结尾是%7D之后大送到手机脚本做成。

这篇关于用Python写一个蛋仔派对自动弹琴脚本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/502223

相关文章

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker