百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

「按键精灵」一篇文章学会节点xml(所谓的全分辨率)

xsobi 2025-01-11 18:15 1 浏览

大家好,我是公众号3分钟学堂的郭立员~

不止一个人问我节点xml怎么学,觉得这个很难,都不知道怎么学习,其实不难。

从初学者的角度来看,先要知道xml节点是什么东西,我们学习xml节点是为了解决什么问题?

对于脚本来说,xml节点就是一堆格式特殊的字符串,我们对xml节点的操作本质上就是对字符串的操作,不用想的太神秘。

xml节点长啥样?看看下面这个截图


把xml代码放到文本里面,初次看到这一大推代码,心里会不会想这是啥玩意乱的很,不过我当初看到时倒还好,因为以前学过一点html网页,有一点框架思维,可以套用一下。

我刚刚说xml节点就是一堆特殊格式的字符串,那么它的格式特殊在哪里?

xml节点是由两部分组成,xml和节点<node>,代码整体叫xml,组成元素是节点<node>,所以我们本质上是研究节点的构成。

那么什么是节点?

打个比方,假设手机屏幕是一个箱子,节点就是一个个盒子。


下面是重点了!!!!

盒子(节点node)有空盒子和满盒子:

①空盒子

<node>这里可以放东西</node>

它是双标签组成,中间可以放别的节点node,注意这里省略了节点的属性,稍后要着重去讲。

放入的内容还可以是空盒子(盒子套盒子),也可以是满盒子。

②满盒子

<node />

它是单标签,所以不能放入其他节点node,仔细对比写法。

对于双标签的node,可以继续放入别的node,而单标签node就不可以了。

可以放多少层node,无限制。。。

讲到这里就引出另外一个关键知识点:层级关系。

因为层级无限制,所以层次之间是什么关系?


大盒子是父级,小盒子是子级,小盒子在大盒子里面,体现到代码上是这样:

子节点是双标签


子节点是单标签


这个关系有点想家谱的父亲、儿子的关系,父级就是父亲,子级就是儿子,儿子又分两种,双标签的节点就是有后代的儿子,而单标签是没有后代的儿子。

一个父亲可能有多个孩子,多个孩子之间的关系是同辈份,在xml中叫同级节点。

同级节点有三种情况:

①全是双标签

②全是单标签


③单双标签混合


在家谱中同辈份,我们怎么区分,是不是叫老大、老二、老三……

在节点中也是这样,这里要提到节点属性中的index属性, index翻译成中文是索引或者序列号。

老大的index=0,老二的index=1,依次类推。

知道父级、子级、同级的关系就差不多了, 至于爷爷级、孙子级就不用了,因为爸爸的爸爸是爷爷、儿子的儿子是孙子,都可以通过父级、子级表示。

节点层级关系的实际作用是关系定位,比如要找一个人的伯伯,可以先确定这个人的父亲(父级节点),找到父亲以后,在根据排行找和父亲同辈份的伯伯(同级节点)。

之所以要用到关系定位,有两种可能的原因,一是因为有些节点的属性值不全,没法直接定位;二是有时候要获取多个数据,并且数据之间是有对应的关系。

我们xml就是由很多很多的node节点以树形结构组成。

了解完节点是什么以后,我们要说说学习xml节点到底解决什么问题?

①获取屏幕上的文字(主要作用)

②获取元素的坐标范围,通常不受分辨率的影响,所以也有人用它做全分辨率的脚本,不过局限性也挺大,比如受手机系统影响、app版本影响、游戏没有节点属性等等。。。

要想实现这两个用途就需要了解节点的属性:

节点属性在哪里?

①双标签:

<node 节点属性></node>

②单标签

<node 节点属性 />

节点属性都包括什么内容?

随机拿出来一个node节点,代码大概是这样的:


上图中我标注了所有属性都是什么,并且用红色字体标注了我们想要获取的两个属性值(text和bounds)

要想获取属性值有两个思路,如果当做普通字符串处理就是用正则匹配或者截取法。

如果按照节点处理,就需要定位node节点,然后根据属性名提取属性值,这种方法也是我们常用的。

重点有来了!!!

定位node节点,最常用的方法根据id值定位,也就是resource-id属性,它相当于节点的名称,根据id找到node,在从node中提取想要属性的值。

为啥是用id定位,因为一般id具有唯一性(相对唯一),用它定位就比较准确。

也有意外情况,比如多个节点id一样,那就把所有符合要求的节点都便利出来,然后看第几个是自己想要的。

还有就是有的节点id是空值,这种情况就不能用该节点的id定位,要看它的父级、子级、同级有没有可以定位的id,如果都没有,在扩大范围,什么爷爷级、孙子级、七大姑八大姨的级别都看看,只要能定位就行。

定位到node以后,要啥节点属性就直接提取啥属性。

具体命令要根据你使用的插件,常用的有山海插件、jsd插件、element插件,喜欢哪个用哪个。

查看节点的工具,抓抓的元素提取,配合element命令使用


jsd的节点查看工具,配合jsd插件使用。



这篇文章标题写“一篇文章学会”有点夸张了,不过这篇文章能够告诉你xml节点的框架结构,了解框架以后就能更好的知道那些命令为啥那样用了。

最后说一下无论你用哪一个命令,认真看命令介绍,这个学好对于学其他编写脚本的软件也有帮助。

好了内容就这些,觉得还行帮忙给文章点个赞。

相关推荐

图解面试题:SQL存储过程有什么用?

面试中有时候会问:存储过程有什么用?看了今天的知识,你就知道如何回答了。1.存储过程是什么?假如你每天要开车完成一些列重复的操作:车钥匙启动车,倒车。现在出现了一款新车,可以自动的完成这些重复的工作。...

零基础入门开始学习SQL Server存储过程

你好啊,我是晨希,今天我们来了解一下SQLServer的存储过程,通过这篇零基础的SQLServer存储过程入门指南文章。您将了解到什么是存储过程,如何创建、调用和优化它们,以及如何提高安全性和性...

SQLSERVER:存储过程和函数

在SQLServer中,存储过程和函数是数据库编程的基础。它们允许开发者编写SQL脚本来执行复杂的操作,同时提供了代码重用和逻辑封装的能力。下面将通过一些实例来详细介绍存储过程和函数的使用。...

数据库基础知识:SQL Server存储过程入门必知

什么是存储过程SQL语句需要先编译然后执行,而存储过程(StoredProcedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储...

SQL储存过程

存储过程是一组预编译的SQL语句,可以保存在数据库中,并作为一个单元执行。它封装了复杂的操作逻辑,可以包含控制结构(如条件判断、循环)、输入参数、输出参数以及错误处理逻辑。存储过程的主要目的是提...

sqlserver开窗及去重row_number() over(partition by c1 order by c2)

开窗函数/分析函数:over()开窗函数也叫分析函数,有两类:一类是聚合开窗函数,一类是排序开窗函数。...

SQL server中exists用法

1、简介?不相关子查询:子查询的查询条件不依赖于父查询的称为不相关子查询?相关子查询:子查询的查询条件依赖于外层父查询的某个属性值的称为相关子查询。带Exists的子查询就是相关子查询...

SQL 将两张包含相同字段和不同字段的表数据合并成一张表

第一种:两个表的相同字段数据查询后合并起来select工号,卡号,姓名,时间from(selectPeople_id工号,People_id卡号,People_name姓名,Rep...

「Oracle」 sql语句查询报错ORA-00904

Oracle报错ORA-00904:标识符无效一般情况下,标识符错误是因为:语句中的列名在表中不存在,修改sql语句或者修改列名即可。...

SQL轻松入门(5):窗口函数

01前言标题中有2个字让我在初次接触窗口函数时,真真切切明白了何谓”高级”?说来也是一番辛酸史!话说,我见识了窗口函数的强大后,便磨拳擦掌的要试验一番,结果在查询中输入语句,返回的结果却是报错,Wh...

SQLServer 日期函数大全

一、统计语句1、--统计当前【>当天00点以后的数据】SELECT*FROM表WHERECONVERT(Nvarchar,dateandtime,111)=CONVERT(Nv...

一文讲懂SQL联合查询UNION

大家好,我是宁一。今天讲解SQL教程第13课:UNION联合查询。...

SQL中的INSERT INTO SELECT语句:数据复制的高效利器

SQL是数据库操作的重要语言,INSERTINTOSELECT语句则是其中的一把利器。本文将详细介绍这一语句的用法和优势,帮助读者更好地理解和运用。一、引言...

SQL server查询-日期操作

常用的sql语句查询:...

sql查询更新update select

针对一个上线的项目进行数据库优化,以便后期统计,遇到一个数据填充的问题,在此记录一下,各位如果也有这种问题,欢迎一起交流。表结构:...