当前位置: 首页 > news >正文

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模块集成到项目,后来测试了会&#xff…...

【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…...

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造,完美适配AGV和无人叉车。同时,集成以太网与语音合成技术,为各类高级系统(如MES、调度系统、库位管理、立库等)提供高效便捷的语音交互体验。 L…...

谷歌浏览器插件

项目中有时候会用到插件 sync-cookie-extension1.0.0:开发环境同步测试 cookie 至 localhost,便于本地请求服务携带 cookie 参考地址:https://juejin.cn/post/7139354571712757767 里面有源码下载下来,加在到扩展即可使用FeHelp…...

【kafka】Golang实现分布式Masscan任务调度系统

要求: 输出两个程序,一个命令行程序(命令行参数用flag)和一个服务端程序。 命令行程序支持通过命令行参数配置下发IP或IP段、端口、扫描带宽,然后将消息推送到kafka里面。 服务端程序: 从kafka消费者接收…...

React hook之useRef

React useRef 详解 useRef 是 React 提供的一个 Hook,用于在函数组件中创建可变的引用对象。它在 React 开发中有多种重要用途,下面我将全面详细地介绍它的特性和用法。 基本概念 1. 创建 ref const refContainer useRef(initialValue);initialValu…...

无人机侦测与反制技术的进展与应用

国家电网无人机侦测与反制技术的进展与应用 引言 随着无人机(无人驾驶飞行器,UAV)技术的快速发展,其在商业、娱乐和军事领域的广泛应用带来了新的安全挑战。特别是对于关键基础设施如电力系统,无人机的“黑飞”&…...

Mysql8 忘记密码重置,以及问题解决

1.使用免密登录 找到配置MySQL文件,我的文件路径是/etc/mysql/my.cnf,有的人的是/etc/mysql/mysql.cnf 在里最后加入 skip-grant-tables重启MySQL服务 service mysql restartShutting down MySQL… SUCCESS! Starting MySQL… SUCCESS! 重启成功 2.登…...

C#学习第29天:表达式树(Expression Trees)

目录 什么是表达式树? 核心概念 1.表达式树的构建 2. 表达式树与Lambda表达式 3.解析和访问表达式树 4.动态条件查询 表达式树的优势 1.动态构建查询 2.LINQ 提供程序支持: 3.性能优化 4.元数据处理 5.代码转换和重写 适用场景 代码复杂性…...

Linux部署私有文件管理系统MinIO

最近需要用到一个文件管理服务,但是又不想花钱,所以就想着自己搭建一个,刚好我们用的一个开源框架已经集成了MinIO,所以就选了这个 我这边对文件服务性能要求不是太高,单机版就可以 安装非常简单,几个命令就…...

HTTPS证书一年多少钱?

HTTPS证书作为保障网站数据传输安全的重要工具,成为众多网站运营者的必备选择。然而,面对市场上种类繁多的HTTPS证书,其一年费用究竟是多少,又受哪些因素影响呢? 首先,HTTPS证书通常在PinTrust这样的专业平…...

【版本控制】GitHub Desktop 入门教程与开源协作全流程解析

目录 0 引言1 GitHub Desktop 入门教程1.1 安装与基础配置1.2 核心功能使用指南仓库管理日常开发流程分支管理 2 GitHub 开源协作流程详解2.1 Fork & Pull Request 模型2.2 完整协作流程步骤步骤 1: Fork(创建个人副本)步骤 2: Clone(克隆…...