Robot Framework(12)- 详细解读 RF 的变量和常量

时间:2020-05-28
本文章向大家介绍Robot Framework(12)- 详细解读 RF 的变量和常量,主要包括Robot Framework(12)- 详细解读 RF 的变量和常量使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

如果你还想从头学起Robot Framework,可以看看这个系列的文章哦!

https://www.cnblogs.com/poloyy/category/1770899.html

常量的栗子

常量就不多说了吧,大家都懂!直接看栗子

上面 log 关键字后面跟的参数都是常量,且类型均是字符串【RF 里面,常量默认是字符串类型,如果需要整形、浮点数、列表,需要调用关键字来转换 or 生成】

变量的介绍

  • RF中的变量,实质上就是一个Python变量,它指向一个Python对象
  • 所以RF变量对应的是什么Python对象,它就是什么类型的对象

变量标识符

{变量名}

 {} 就是变量标识符

RF 的变量类型

变量类型 变量中文 写法
scalar 标量  ${SCALAR} 
list 列表  @{LIST} 
dict 字典  &{DICT}  
环境变量 环境变量  %{ENV_VAR} 

变量的作用就不说了哈,大家应该都知道~

变量的注意事项

  • 不区分大小写: ${var} 和 ${VAR} 指向同一个对象
  • 变量名若有下划线和空格都会被忽略: ${my var}  或  ${myVar} 

测试代码

 测试结果

Scalar 变量

特点

  • 当传递 Scalar 变量给关键字作为参数的时候, 就是直接把它所对应的 Python 对象类型传递给关键字对应的函数
  • 每个 List 变量和 Dict 变量,也是 Scalar 变量

测试代码

测试结果

知识点

  • 在 Variables 表中定义变量,可以直接在变量后面跟值,不用加 set variable 
  • 给标量赋值,声明变量后面可加=,也可不加
  • 在 Test Cases 表中定义变量,声明变量之后,一定要接 set variable 或 set variable if 关键字,然后再接需要设置的值
  • 变量间,可以互相赋值

List 变量

List 变量的介绍

如果一个标量的值是一个列表,或者类似列表的其它序列,可以将该变量作为列表变量使用,格式为 @{EXAMPLE}

Variables 表中定义列表变量的栗子

直接声明变量名,然后接值就可以了

重点:不同值之间也要空两个空格,不然 RF 会识别成同一个元素值

Test Case 表中定义列表变量的栗子

测试结果

测试代码分成了四部分

  1. 声明列表变量,有两种声明列表变量的方式,以及两种生成列表值的方式
  2. 打印列表
  3. 循环打印
  4. 获取列表长度

我们来看看上述 RF 代码等价于 Python 的话,会是咋样的

@{lists} 和 ${lists} 的区别

  • 列表变量也是标量的一种,只是值是列表,所以可以看成列表变量
  • ${lists} 可以看成是一个列表整体, @{lists} 可以看成整体拆成一个个单独的元素
  • ${lists} 在 Python 里面就是一个 list ,然后 @{lists} 就是展开其 lists 中的每个元素,作为多个参数传入,和 *args 一样效果,在Python 里叫可变参数【可看这篇博文:https://www.cnblogs.com/poloyy/p/12526592.html

我们将它们等价到Python 里面去看,这样更好理解

def printarg(*args):
    if len(args) == 0:
        print('** no args **')
    else:
        print('** args are **')
        print('-----------------')
        for one in args:
            print(repr(one))
        print('-----------------')


# 等价于 RF 的写法:printarg  ${lists}
printarg(lists)

# 等价于 RF 的写法:printarg  @{lists}
printarg(*lists)

测试结果

** args are **
-----------------
[1, 2, 3, 4, 5]
-----------------
** args are **
-----------------
1
2
3
4
5
-----------------

获取列表变量中的值

一共两种获取的格式

  1.  ${变量名}[下标值] 
  2.  ${变量名[下标值]} 

测试结果

知识点

  • 系统也提示啦,我们应该用 ${list}[0] 这种格式来代替 @{list} 获取列表的某个值
  • 下标也是从 0 开始
  • 下标可以传变量 ${list}[${index}] 

Dict 变量

Dict 变量介绍

如果一个标量的值是一个字典,可以将该变量作为字典变量使用,格式为  &{EXAMPLE} 

Variables 表中定义字典变量的栗子

直接声明变量名,然后接 即可,注意声明字典变量一定要用 &{dicts} 的格式

重点:不同key=value之间也要空两个空格,不然 RF 会识别成同一个值

Test Case 表中定义字典变量的栗子

测试结果

我们来看看上述 RF 代码等价于 Python 的话,会是咋样的

&{dict} 和  ${dict} 的区别

  • 字典变量也是标量的一种,只是值是字典,所以可以看成字典变量
  • ${dict} 可以看成是一个完整的字典对象, &{dict} 可以看成整体拆成一个个单独的键值对
  • ${dict} 在 Python 里面就是一个  dict ,然后&{dict} 就是展开其 dict 中的每个键值对,作为多个参数传入,和 **kwargs 一样效果,在Python 里叫关键字参数【可看这篇博文:https://www.cnblogs.com/poloyy/p/12526592.html

我们将它们等价到Python 里面去看,这样更好理解

def printarg(**kwargs):
    if len(kwargs) == 0:
        print('** no kwargs **')
    else:
        print('** kwargs are **')
        print('-----------------')
        for k, v in kwargs.items():
            print(repr(k) + ':' + repr(v))
        print('-----------------')

# 等价于 RF 的写法:printarg  &{dicts1}
printarg(**dicts1)

测试结果

** kwargs are **
-----------------
'name':'yy'
'age':19
-----------------

获取字典变量中的值

只有一种获取格式: ${dicts}[key] 

测试结果

知识点

  • 系统也提示啦,我们应该用 ${dicts}[key] 代替 &{dicts}[key] 
  • 键可以传变量 &{DICT}[${KEY}] 
  • 重点: ${dict.key} 会报错哦,不可取

原文地址:https://www.cnblogs.com/poloyy/p/12939615.html