• 接口测试时,数据处理需要注意的细节


    一、json模块中的dumps方法

    请求接口时params肯定是dict类型的,就是这种{"A":"B"},因为需要传json格式的参数到服务端,但是为了降低case的维护成本,参数不会进行写死,一般会从数据库中拿参数,在服务端有强校验的情况下,格式不正确的参数就会报错,比如说{“KEY”:{'A':B}}这里面value在没有encoding前是dict类型,在请求对应接口时就会response['code']一直非0。

    json模块中的dumps方法可以很好的解决上面的问题

    >>> import json

    >>> a={'a':{'key1':1,'key2':(1,2),'key3':[1,2,3],4:"aa"}}

    >>> b=json.dumps(a)

    >>> print b

    {"a": {"key3": [1, 2, 3], "key2": [1, 2], "key1": 1, "4": "aa"}}

    首先b["a"]["key2"]的value的类型原来是元组类型经过encoding后变成list

    其次b["a"][4]其中4的类型是int型的经过encoding后变成string类型

    json.dumps()还增加了排序参数sort_keys (适用于python2,python3当然也有类似的用法)

    >>> c=json.dumps(a,sort_keys=True)

    >>> print c

    {"a": {"4": "aa", "key1": 1, "key2": [1, 2], "key3": [1, 2, 3]}}

    这个排序是按照字典的(a到Z)排序

    json.dumps()有一个参数indent可以增加缩进方便查看 

    >>> d=json.dumps(a,sort_keys=True,indent=3)

    >>> print d

    {

       "a": {

          "4": "aa", 

          "key1": 1, 

          "key2": [

             1, 

             2

          ], 

          "key3": [

             1, 

             2, 

             3

          ]

       }

    }

  • 相关阅读:
    Selenium学习:选择元素的几种方法
    Selenium学习:find_element_by_xpath()的几种方法
    Selenium 循环删除页面元素
    Java 基础(main方法介绍)
    Java 基础(单例 Singleton 设计模式)
    Java 练习(static 关键字)
    Java 基础(static 关键字)
    Java 练习(包装类 Wrapper )
    Java 基础(包装类 Wrapper 的使用)
    Java 练习(Object 练习二)
  • 原文地址:https://www.cnblogs.com/ailiailan/p/9122252.html
Copyright © 2020-2023  润新知