python自动化脚本常用代码

1.case = os.path.basename(path)  

    使用os.path.basename()函数从给定的path中提取出文件名或目录名,不包含路径前缀。结果被赋值给变量case。例如,如果path是"/home/user/documents/report.txt",那么case将会是"report.txt"

2.msg = result[result.index('msg:') + 4: result.rindex('}')+1]  

查找子串:
   result.index('msg:'):找到字符串result中子串'msg:'的起始位置。
   result.rindex('}'):找到字符串result中最后一个'{'字符的位置。
切片操作:
   使用上述找到的位置进行切片操作,从'msg:'后第四个字符开始(即'msg:'之后的第一个字符),直到字符串中最后一个'{'字符结束(包括'{'字符本身)。这个切片操作的结果被赋值给变量msg。

3.ft.write_str 

用于将字符串写入文件

    第一个参数通常是文件句柄或文件名,指明写入的目标文件。
    第二个参数是要写入的字符串内容。
    第三个参数是写入模式,如'w'代表写入模式(会清空原有内容),'a'代表追加模式(在文件末尾追加内容)。

4.dis = ft.time_dis(send_time, resp_time, "%Y-%m-%d %H:%M:%S.%f")

按照"%Y-%m-%d %H:%M:%S.%f"格式的字符串,计算两个时间点之间的差值

5.arr = ft.read_list(f, errors='ignore')

    调用了ft.read_list函数,参数f通常是一个文件对象,表示要读取的文件。
errors='ignore'参数意味着在读取文件时,如果遇到编码错误,函数将忽略这些错误而不是抛出异常。
    ft.read_list函数执行后,返回值arr应该是一个列表,其中包含了文件中每一行的内容,每一行内容作为一个单独的字符串元素存在于列表中。
    这样做的目的是为了读取文件内容并将其转换为列表形式,便于后续的数据处理或分析,同时通过设置errors='ignore'选项,可以避免因文件中的编码问题而导致程序中断

6.arr_tmp = re.split(",| ", x)

    re.split(",| ", x):使用re.split函数根据逗号,和空格来分割字符串x。
    正则表达式",| "表示逗号或空格作为分隔符,|符号在这里表示“或”。 

7.end_time = f"{arr_tmp[0]} {arr_tmp[1]}"

将arr_tmp列表中的第一个和第二个元素组合成一个新的字符串send_time。 

8.re.search()

    re.search是Python标准库re(正则表达式)模块中的一个函数,用于在字符串中搜索匹配正则表达式的第一个位置,返回match对象。如果未找到匹配项,则返回None 

9.str(count)

这行代码的功能是将变量count的值转换为字符串类型。str()是Python内置的一个函数 

10.text = ft.read_text(name + ".txt").replace("\r\n", "|")

文件读取:
     ft.read_text(name + ".txt"):调用ft.read_text函数,参数是通过字符串拼接产生的文件                            名即name变量后加上.txt扩展名。这个函数负责打开并读取指定的文本文件内容。

替换换行符:
    .replace("\r\n", "|"):对读取到的文本内容进行处理,将所有的回车换行符"\r\n"替换   为"|"字符。这通常用于统一文本格式,使得原本由换行符分隔的行现在可以通过单一字符(如管道符|)来区分,便于后续的数据处理或分析

11.text = re.sub(r"\s+", " ", text).strip()

替换多余空白字符:
    re.sub(r"\s+", " ", text):使用正则表达式r"\s+"来匹配一个或多个空白字符(包括空格、制表符、换页符等),并将其替换为单个空格。这里的+表示匹配一个或多个连续的空白字符,从而将连续的空白字符压缩为一个空格。
去除首尾空白:
    .strip():在替换操作后,使用strip()方法去除字符串text开头和结尾的空白字符,包括空格和制表符等。
结果:
    经过这两步处理后,text中的所有连续空白字符都会被简化为一个空格,且字符串两端的空白字符也被移除,使文本更加整洁规范。

12.j["audio_file"] = audio_list

    这行代码的功能是将audio_list的值赋给字典j中的"audio_file"键。具体来说:
    j:这是一个字典,可以存储键值对数据。
    "audio_file":这是字典j中的一个键,用来标识特定的数据项。
    audio_list:这应该是包含音频文件信息的列表或字符串,具体取决于上下文。 

13.json.loads(ft.read_text("config.ini"))

读取文件内容:
    ft.read_text("config.ini"):调用ft.read_text函数读取config.ini文件的内容。这里假设ft模块提供了一个可以读取文本文件并返回其内容的函数。
JSON解析:
    json.loads(...):使用Python标准库中的json模块的loads函数,将上一步读取到的文本内容解析为Python数据结构,通常是字典或列表,具体取决于JSON数据的结构。
结果:
    最终结果是一个可以从config.ini文件中解析出来的Python字典或列表,使得配置文件中的数据可以像普通Python数据一样被访问和使用。 

14.kvs.items()

    kvs = {'a': 1, 'b': 2, 'c': 3}
for key, value in kvs.items():
    print(f"Key: {key}, Value: {value}")
    通过调用 items() 方法,可以轻松地遍历字典的键值对,进行各种数据处理和分析任务。这种方法比使用 keys() 或 values() 更加高效和直观,因为它同时提供了键和值的信息,避免了额外的查找操作。 

15.for on_off_line in [1]:
    print(on_off_line) 

运行这段代码会输出数字1,因为列表中只有这一个元素,所以循环只会执行一次

16.arr = ft.walk_dir(wav_path)

    walk_dir(wav_path)函数的作用是遍历wav_path目录下所有的文件和子目录,返回一个包含所有文件路径的列表arr 

17.x = x.strip()

    strip()方法会从字符串的两端删除空白字符(包括空格、制表符、换页符等),如果字符串中只有空白字符,则返回一个空字符串。 

18.if not x.endswith('.wav'): continue

    检查字符串变量x是否以.wav后缀结束。
    如果x不以.wav结尾,那么if not x.endswith('.wav')条件为真,执行continue语句。
    continue语句会跳过当前循环迭代中的剩余代码,直接进入下一次循环。

 19.path = wav_path + '/' + os.path.basename(x).replace(".wav", ".txt")

    提取文件名:os.path.basename(x)从完整路径x中提取出文件名部分,不包括路径前缀。
    替换后缀:.replace(".wav", ".txt")将提取出的文件名中的".wav"后缀替换为".txt",实现从音频文件到文本文件的转换。
    构建新路径:wav_path + '/' + ...将wav_path目录与修改后的文件名拼接起来,形成新的文件路径path,指向与原音频文件同名但扩展名为".txt"的文本文件。

20.data = file1.read().replace(x+" ", "")

    读取文件内容:file1.read()从打开的文件对象file1中读取所有内容到字符串变量data中。
    替换字符串:.replace(x+" ", "")将读取到的data中的特定模式(即x文件路径后面紧跟的一个制表符)替换为空字符串,实质上是移除了这一部分。
    x+" "构造了一个字符串,由文件路径x和一个制表符组成。
    ""是替换后的值,意味着这部分内容将被删除。

21.os.chdir("../"+demo_dir)

将当前工作目录切换到上级目录中的demo_dir目录下

22.dic = ft.walk_file_dic(wav_dir)

    walk_file_dic函数会遍历wav_dir目录及其子目录下的所有文件,返回一个字典,其中键为文件的相对路径,值通常为文件的相关信息

 23.tmp = re.split(r'\s+', x.strip())

    调用strip()方法:首先去除字符串x两端的空白字符,包括但不限于空格、制表符等。
    使用正则表达式分割字符串:接着使用re.split()函数,通过正则表达式r'\s+'来进一步分割处理过的字符串x。这里的正则表达式\s+匹配一个或多个空白字符,因此re.split(r'\s+', ...)会根据一个或多个连续的空白字符将字符串切分为多个子串。
    结果存储:最终得到的分割后的子串列表会被存储在变量tmp中。每个子串都是原字符串x中由空白字符分隔的部分。

24.text = ' '.join(tmp[1:])

    从列表tmp的第二个元素开始到最后一个元素,即tmp[1:],选取所有元素。
    使用' '.join(...)方法将上述选取的元素以单个空格(' ')为分隔符连接成一个新的字符串。
    最终形成的字符串存储在变量text中。此操作常用于去除列表中的第一个元素,对剩余元素进行整合,特别是在处理通过分隔符拆分的文本数据后重新构建文本字符串时。

25.ft.write_str(report, "")

    write_str函数的作用是向report指定的文件写入内容。在这里,由于第二个参数是一个空字符串,因此实际上是对report文件进行清空操作,即删除文件中的所有现有内容,使其成为一个空文件。

26. arr_time_load_mode.append(dis)

    将变量dis的值添加到列表arr_time_load_mode的末尾。
    append()方法用于在列表的最后增加一个新元素,这里的dis可以是任何类型的数据,只要它与列表中已有的元素类型兼容或列表允许存储多种类型的元素

27.request_id = re.search("request_id:(.*?),", x).group(1)

    正则表达式搜索:使用正则表达式"request_id:(.*?),"在字符串x中搜索匹配项。这个正则表达式旨在匹配request_id:后面的任意字符直到遇到第一个逗号(,),括号内的(.*)表示捕获这部分内容。
    获取第一个匹配组:.group(1)获取正则表达式中第一个括号内捕获的内容,即request_id:后面直至逗号前的字符串

28.results = gen_req_map(thread_lines)

    调用了gen_req_map函数,并将thread_lines作为参数传递给它。
    gen_req_map函数的作用通常是根据输入的thread_lines(可能是一个包含多行文本或数据的列表)生成一个映射(字典)。
    这个映射可能将每行数据中的某个关键字段(如请求ID)映射到该行的其他相关信息,从而方便后续对数据的查询和处理。

29.file.readlines()

    file.readlines() 是 Python 文件对象的一个方法,用于读取整个文件内容,并返回一个列表,列表中的每个元素对应文件中的一行

30.

def create_id(self):
    m = hashlib.md5(str(time.perf_counter()).encode("utf-8"))
    return m.hexdigest()

    该函数用于生成一个基于时间的唯一标识符。它通过获取当前时间(使用 time.perf_counter()),将其转换为字符串,并使用hashlib.md5()生成一个MD5散列值。最后,使用hexdigest()方法将散列值转换为16进制字符串并返回。这个函数可以用于创建唯一的标识符,例如在数据库中标识记录

31.

frame = pd.DataFrame(self.all_results,
                     columns=['用例1', '用例设计2', '用例3'])

    1.这行代码创建了一个pandas DataFrame 对象,DataFrame是一种二维表格型数据结构。具体步骤如下:
    2.数据来源:使用self.all_results作为数据源,self.all_results应该是一个列表或类似可迭代的数据结构,其中每个元素包含了测试用例的相关信息。
    3.列名定义:通过columns参数指定了DataFrame的列名,分别是'用例名称', '请求报文', '返回报文'。
    4.DataFrame创建:pd.DataFrame是pandas库中用于创建DataFrame的方法。这里,self.all_results中的数据会被组织成表格形式,按照指定的列名进行分类。
    5.执行完这行代码后,frame变量就存储了一个DataFrame,可以方便地对测试用例的数据进行查看、筛选和分析。

32.

print("输出参数:{}".format(res))

    这行代码使用print函数和字符串格式化的方法来输出信息。具体来说:
    1."输出参数:{}".format(res) 这部分是一个格式化的字符串,其中的{}是一个占位符,表示将在此处插入一个值。format(res)则指定了这个占位符将被res变量的值所替换。
    2.当这行代码被执行时,它会在控制台上打印出一条消息,消息的内容是"输出参数:"后面跟着res变量的值。例如,如果res的值是{'key': 'value'},那么输出将会是:输出参数:{'key': 'value'}

33. 

  • 9
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值