Python 为UnityAndroid端自动化接入Tradplus广告SDK
Python 为UnityAndroid端自动化接入Tradplus广告SDK
- Tradplus介绍
- 常规接入
- 进入Android开发文档
- 选择渠道配置
- 生成接入代码
- 人工依赖
- 下载官网同版本的 Unity插件
- 使用自动化工具接入
- 首次 你需要打两个标记来定位
- 运行工具 控制台会列出最新的十个Tradplus版本 任选其一
- 然后拖入项目路径后回车开始植入最新版
- 植入完成后 控制台会输出 end. 这时候工具运行目录下 会自动下载好指定Tradplus版本的Unity插件
- 其它声明
- 渠道配置
- ADMOB BIDDING自定义配置
- 源码
Tradplus介绍

常规接入
进入Android开发文档
技术文档: https://docs.tradplusad.com/docs/tradplussdk_android_doc_v6/download
选择渠道配置

生成接入代码

人工依赖
容易出错 新人入手也比较麻烦

下载官网同版本的 Unity插件

使用自动化工具接入
首次 你需要打两个标记来定位
在Traplus接入开头处 加上
/// TradPlus Start //

在Tradplus接入结尾处 加上
/// TradPlus End //

运行工具 控制台会列出最新的十个Tradplus版本 任选其一

然后拖入项目路径后回车开始植入最新版


植入完成后 控制台会输出 end. 这时候工具运行目录下 会自动下载好指定Tradplus版本的Unity插件

其它声明
渠道配置
修改配置文件 ads 需要接入的广告渠道配置
仅需要在第一次和每次运营更换广告渠道的时候 配置一次

ADMOB BIDDING自定义配置
一般情况下这个版本号是Tradplus官方的人来告诉你这是哪个版本号 改一次就好了

源码
主运行脚本
#默认服务端口import requests
import time
import implant
import downloadUnityPluginsapi = 'https://www.geek7.top:8000/api'
adsChannel = ['UnityAds']
region = '2' # 1: 中国 2: 其它地区adsChannel.clear()
sdkversionList = []
versionstr = ""
def log( msg ):print( msg )def InitChannel():adsChannel.clear()with open('./bin/ads','r') as fp:for line in fp.readlines():adsChannel.append(line.replace('\n',''))def Run( sdk_version = "10.2.0.1",overrid = True ):global versionstrInitChannel()data = {'token' : time.time(),'pipe':'tradplussdk','code':829,'adchannels':','.join(adsChannel),'version':sdk_version,'region' : region}res = requests.get(api,data) j = res.json()if 'version' not in j:log('erro: not foud version property in result.data')returnif 'data' not in j:log('erro: data not in depends')returnappGradleCode = j['data']if None == appGradleCode:log('GetDependencies fail')else:print('input you "Assets\\Plugins\\Android" full path')print('example: D:\\Git\\2dtoilet\\2dtoilet-client\\Assets\\Plugins')print('Or you can try the Android folder to this window.')print('current tradplus version list:')v = j['version']versionstr = '|'.join(v.split(',')[0:10])print(versionstr)if not overrid:sdkversionList.clear()sdkversionList.extend(v.split(','))returnsrcpath = input('input proj:\n')realpath = srcpath.replace('\\','/')implant.Run(realpath,appGradleCode)u3dzip = j['u3dzip']print(f'download unity plugin: {u3dzip}')downloadUnityPlugins.dowanlodZip(u3dzip,'./tradplus_unity_plugin_zips')if __name__ == "__main__":log('begin.')Run( "10.2.0.1", False )version = ""while True:version = input('input you tradplus version: ')print(f'pulling the current version dependency of Tradplus: {version}')if version in sdkversionList:breakelse:print(f'current version fail. :{version}')print(versionstr)Run( version )input('end.')
自动化植入mainTemplate.gradle脚本
import osdef Run( projpath, dependsContent ):print(f'project path: {projpath}')print(f'depend content: {dependsContent}')if not projpath.endswith('mainTemplate.gradle'):projpath = os.path.join(projpath,'mainTemplate.gradle')filterstr = ''dependlines = dependsContent.splitlines()tradplusContent = Falseadmob = Falseadmob_bidding = Falseadmob_bidding_str = "22.1.0.0"with open('./bin/ADMOB BIDDING','r') as fp:lines = fp.readlines()if len(lines) > 0:admob_bidding_str = lines[0]print(f"ADMOB BIDDING : {admob_bidding_str}")for l in dependlines:if l.startswith('dependencies {'):tradplusContent = Trueelif l.startswith('android {'):filterstr = filterstr[0:-2]breakelif tradplusContent:real = l.replace('\"','\'')if admob:admob = Falsesi = real.find('\'')ei = real.find('\'',si+1)com = real[si:ei+1]_import = ''' implementation(%s) {exclude module: "play-services-measurement-sdk-api"}\n'''%(com)filterstr += _importadmob_bidding = Truecontinueif admob_bidding and '// ' in real:_import = ''' //ADMOB BIDDINGimplementation ('com.applovin.mediation:google-adapter:%s'){exclude module: "play-services-measurement-sdk-api"}\n'''%(admob_bidding_str)filterstr += _importadmob_bidding = Falseif '// Admob' in real:admob = Truefilterstr += f'{real}\n'output = ''with open(projpath,'r',encoding='UTF-8') as fp:begin_write = Falselines = fp.readlines()for line in lines:if line.startswith(' /// TradPlus Start //'):output += ' /// TradPlus Start //\n'output += filterstrbegin_write = Trueelif line.startswith(' /// TradPlus End //'):output += ' /// TradPlus End //\n'begin_write = Falseelif not begin_write:output += lineif len(output) != 0 and output != '':print('Under implantation.')with open(projpath,'w',encoding='UTF-8') as fp:fp.write(output)print('Complete implantation.')else:print('got a little problem')
下载unity最新插件脚本
import requests
import zipfile
import tempfile
import osdef get_data( url ):response = requests.get(url)return url, response.contentdef dowanlodZip( url , dest = "./zip"):url, data = get_data( url ) # data为byte字节_tmp_file = tempfile.TemporaryFile() # 创建临时文件print(_tmp_file)_tmp_file.write(data) # byte字节数据写入临时文件# _tmp_file.seek(0)print(f'extract to: {os.path.join(os.getcwd(),dest)}')zf = zipfile.ZipFile(_tmp_file, mode='r')for names in zf.namelist():f = zf.extract(names, dest) # 解压到zip目录文件下print(f)zf.close()print('extract completed')相关文章:
Python 为UnityAndroid端自动化接入Tradplus广告SDK
Python 为UnityAndroid端自动化接入Tradplus广告SDK Tradplus介绍常规接入进入Android开发文档选择渠道配置生成接入代码人工依赖下载官网同版本的 Unity插件 使用自动化工具接入首次 你需要打两个标记来定位运行工具 控制台会列出最新的十个Tradplus版本 任选其一然后拖入项目…...
Matplotlib基础
目录: 一、绘制yx^2图像: 一、绘制yx^2图像: from matplotlib import pyplot as plt import numpy as np #生成(-50,50)的数组 x np.arange(-50,50) #计算因变量y的值 y x ** 2 #根据x、y数组绘制图形yx^2 plt.plot…...
上海东海职业技术学院低代码实训平台建设项目竞争性磋商公告
上海东海职业技术学院低代码实训平台建设项目竞争性磋商公告 招标|招标公告 上海市|闵行区 项目编号:0773-2340GNSHFWCS2823 招标单位:上海东海职业技术学院 代理单位:中金招标有限责任公司 预算金额:59万元 联系方式&…...
c语言之将输入的十进制转换成二进制数并打印原码反码补码
十进制转二进制 首先,我们要知道的是十进制转换成二进制数的方法。我们一般采用的除二取余的方法,在这里我用32位数组来进行转换。 int main() {printf("请输入一个十进制数\n");int n 0;scanf("%d", &n);int arr[32];int* p…...
算法题明明的随机数
第一行先输入随机整数的个数 N 。 接下来的 N 行每行输入一个整数,代表明明生成的随机数。 具体格式可以参考下面的"示例"。 import java.util.Iterator; import java.util.Scanner; import java.util.TreeSet; // 注意类名必须为 Main, 不要有任何 pa…...
B站不赚钱、“芒果”赚钱难,视频“后浪”火拼跨年夜
又是一年跨年时。 各大视频平台跨年晚会展开火拼,今年谁是赢家? 作为视频“后浪”,芒果超媒(300413.SZ)、哔哩哔哩(09626.HK,下称“B站”)此前相继公布了2023年三季报,…...
ajax请求的详细流程+详细示例
AJAX(Asynchronous JavaScript and XML)是一种用于创建异步 Web 应用程序的技术。下面是 AJAX 请求的详细流程: 创建 XMLHttpRequest 对象:在 JavaScript 代码中,使用 new XMLHttpRequest() 创建一个 XMLHttpRequest 对…...
这些产品手册制作工具,你都值得收藏
产品手册是企业向消费者传达产品信息的重要媒介,它能够直接影响消费者对产品的了解和购买决策。然而,制作一份专业而吸引人的产品手册并非易事,需要一定的设计和排版能力。为了帮助企业和个人更轻松地制作出优质的产品手册,下面将…...
跨账号和同账号的ECS云服务器之间迁移教程
阿里云ECS实例间迁移场景如下: 场景一:跨账号ECS实例间迁移 此场景适用于跨账号,同地域或者跨地域下的ECS实例间的迁移。例如:将阿里云账号A下的ECS实例,迁移阿里云B账号下。 场景二:同账号ECS实例间迁移 …...
python virtualenv 虚拟环境命令
# 安装 virtualenv pip3.9 install virtualenv # 创建虚拟环境test mkdir /envs # 创建一个文件夹放置虚拟环境 cd /envs/ virtualenv /envs/test # --pythonpython3.9 # 激活虚拟环境test source /envs/test/bin/activate # 安装依…...
深入理解MySQL索引底层数据结构
听课问题(听完课自己查资料) 什么是二叉树 二叉树是怎么存储数据的一个链表是一个集合的数据结构 List是怎么便利找到指定下标元素为什么会快?什么是红黑树 红黑树是怎么存储数据的什么是B TREE 是怎么存储数据的什么是BTREE 是怎么存储数据的 疑惑答案 a. 二叉树…...
使用 Tkinter 制作一个进制转换工具,好用!
在平时工作学习当中,我们经常会编写一些简单的 Python GUI 工具,以此来完成各种各样的自动化任务,比如批量处理文件,批量处理图片等等。当我们进行这些工具的编写之时,往往只关注了功能的实现,而忽略了页面…...
Final Cut 视频剪辑快速入门,小白上手视频课的制作
本文是一个快速入门教程,如果您是0视频处理基础,又想录制网课或是一些对效果要求不高的视频那么这篇教程足够使用了。 本文主要用Final Cut处理视频课,本文是笔者在制作视频课过程中逐渐摸索的,如果您想制作一些比较专业的视频&a…...
分布式定时任务Xxl_Job详细使用手册
看了很多网上的版本,思路描述的都不是很清晰,都只是几步操作就完成了,看效果,导致容易走入弯路(不排除是自己理解能力把),最开始以为是把admin模块集成到项目,后来测试了会ÿ…...
【PostgreSQL】表操作-修改表
【PostgreSQL】表操作快速链接 创建表及基础表命令 修改表 表权限 添加列 ALTER TABLE products ADD COLUMN description text;新列最初填充给定的任何默认值DEFAULT(如果未指定子句,则为 null)。 注意: 从 PostgreSQL 11 开始…...
【Java系列】文件操作详解
个人主页:兜里有颗棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创 收录于专栏【Java系列专栏】【JaveEE学习专栏】 本专栏旨在分享学习JavaEE的一点学习心得,欢迎大家在评论区交流讨论💌 目录 …...
docker-compose 安装 RocketMq
目录 1、rocketMq 官网 2、工作流程 RocketMQ集群工作流程 1. 启动NameServer 2. 启动 Broker 3. 创建 Topic...
【心得】PHP反序列化高级利用(phar|session)个人笔记
目录 ①phar反序列化 ②session反序列化 ①phar反序列化 phar 认为是java的jar包 calc.exe phar能干什么 多个php合并为独立压缩包,不解压就能执行里面的php文件,支持web服务器和命令行 phar协议 phar://xxx.phar $phar->setmetadata($h); m…...
MyBatisPlus之增删改查
系列文章目录 提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加 MyBatisPlus之增删改查 提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 系列文章目录前言一、什么是Mybati…...
pytorch03:transforms常见数据增强操作
目录 一、数据增强二、transforms--Crop裁剪2.1 transforms.CenterCrop2.2 transforms.RandomCrop2.3 RandomResizedCrop2.4 FiveCrop和TenCrop 三、transforms—Flip翻转、旋转3.1RandomHorizontalFlip和RandomVerticalFlip3.2 RandomRotation 四、transforms —图像变换4.1 t…...
【人工智能】神经网络的优化器optimizer(二):Adagrad自适应学习率优化器
一.自适应梯度算法Adagrad概述 Adagrad(Adaptive Gradient Algorithm)是一种自适应学习率的优化算法,由Duchi等人在2011年提出。其核心思想是针对不同参数自动调整学习率,适合处理稀疏数据和不同参数梯度差异较大的场景。Adagrad通…...
Mybatis逆向工程,动态创建实体类、条件扩展类、Mapper接口、Mapper.xml映射文件
今天呢,博主的学习进度也是步入了Java Mybatis 框架,目前正在逐步杨帆旗航。 那么接下来就给大家出一期有关 Mybatis 逆向工程的教学,希望能对大家有所帮助,也特别欢迎大家指点不足之处,小生很乐意接受正确的建议&…...
Redis数据倾斜问题解决
Redis 数据倾斜问题解析与解决方案 什么是 Redis 数据倾斜 Redis 数据倾斜指的是在 Redis 集群中,部分节点存储的数据量或访问量远高于其他节点,导致这些节点负载过高,影响整体性能。 数据倾斜的主要表现 部分节点内存使用率远高于其他节…...
VM虚拟机网络配置(ubuntu24桥接模式):配置静态IP
编辑-虚拟网络编辑器-更改设置 选择桥接模式,然后找到相应的网卡(可以查看自己本机的网络连接) windows连接的网络点击查看属性 编辑虚拟机设置更改网络配置,选择刚才配置的桥接模式 静态ip设置: 我用的ubuntu24桌…...
C++.OpenGL (20/64)混合(Blending)
混合(Blending) 透明效果核心原理 #mermaid-svg-SWG0UzVfJms7Sm3e {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-SWG0UzVfJms7Sm3e .error-icon{fill:#552222;}#mermaid-svg-SWG0UzVfJms7Sm3e .error-text{fill…...
Java求职者面试指南:计算机基础与源码原理深度解析
Java求职者面试指南:计算机基础与源码原理深度解析 第一轮提问:基础概念问题 1. 请解释什么是进程和线程的区别? 面试官:进程是程序的一次执行过程,是系统进行资源分配和调度的基本单位;而线程是进程中的…...
【C++特殊工具与技术】优化内存分配(一):C++中的内存分配
目录 一、C 内存的基本概念 1.1 内存的物理与逻辑结构 1.2 C 程序的内存区域划分 二、栈内存分配 2.1 栈内存的特点 2.2 栈内存分配示例 三、堆内存分配 3.1 new和delete操作符 4.2 内存泄漏与悬空指针问题 4.3 new和delete的重载 四、智能指针…...
elementUI点击浏览table所选行数据查看文档
项目场景: table按照要求特定的数据变成按钮可以点击 解决方案: <el-table-columnprop"mlname"label"名称"align"center"width"180"><template slot-scope"scope"><el-buttonv-if&qu…...
消息队列系统设计与实践全解析
文章目录 🚀 消息队列系统设计与实践全解析🔍 一、消息队列选型1.1 业务场景匹配矩阵1.2 吞吐量/延迟/可靠性权衡💡 权衡决策框架 1.3 运维复杂度评估🔧 运维成本降低策略 🏗️ 二、典型架构设计2.1 分布式事务最终一致…...
第八部分:阶段项目 6:构建 React 前端应用
现在,是时候将你学到的 React 基础知识付诸实践,构建一个简单的前端应用来模拟与后端 API 的交互了。在这个阶段,你可以先使用模拟数据,或者如果你的后端 API(阶段项目 5)已经搭建好,可以直接连…...
