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

python实现自动化测试框架如何进行数据参数化?这个包可以了解下

1.数据参数化介绍

只要你是负责编写自动化测试脚本的,数据参数化这个思想你就肯定会用 ,数据参数化的工具你肯定的懂一些 ,因为它能大大的提高我们自动化脚本编写效率 。

1.1什么是数据参数化

所谓的数据参数化 ,是指所执行的测试用例步骤相同、而数据不同 ,每次运行用例只变化的是数据 ,于是将这些数据专门放在一起进行批量循环运行 ,从而完成测试用例执行的目的 。

以登录功能为例 ,若一个登录功能每次操作的步骤是 :

  1. 输入用户名
  2. 输入密码
  3. 点击登录按钮 。

但是,因为每次输入的数据不同,导致生成的测试用例就不同了 ,同样还是这个登录功能,加上数据就变为以下的用例了 。

  • case1 : 输入正确的用户名 ,输入正确的密码 ,点击登录
  • case2 : 输入正确的用户,输入错误的密码,点击登录
  • case3 :输入正确的用户名,输入空的密码,点击登录
  • casen : ...

可以看到 ,在这些用例中,每条用例最大的不同是什么呢 ?其实就是数据不同 。但是由于数据不同,从而生成了多条测试用例 ,在功能测试中,这些用例是需要分别写、分别执行 。

1.2.为什么要进行数据参数化 ?

在功能测试中,即使是相同的步骤 ,只是数据不同 ,我们亦然也要尽量分开编写每一条用例 ,比如像上面的编写方式 ,因为这些编写它的易读性更好 ,功能测试设计测试用例和执行用例往往不是一个人 ,所以用例编写的易读性是就是一个很重要的因素 。

但是如果将上面的用例进行自动化实现 ,虽然按照一条用例对应一个方法是一种很清晰的思路 ,但是它的最大问题就是代码冗余 ,当一个功能中步骤相同,只是数据不同时,你的数据越多,代码冗余度就越高 。你会发现每个测试方法中的代码就会是相同的 。

像代码冗余这种问题,在编写自动化时是必须要考虑的一个问题,因为随着代码量越多 ,冗余度越高、越难维护 。

以下就是是通过正常方式实现登录的自动化脚本 :

  1. import unittest

  2. from package_unittest.login import login

  3. class TestLogin(unittest.TestCase):

  4. # case1 : 输入正确的用户名和正确的密码进行登录

  5. def test_login_success(self):

  6. expect_reslut = 0

  7. actual_result = login('admin','123456').get('code')

  8. self.assertEqual(expect_reslut,actual_result)

  9. # case2 : 输入正确的用户名和错误的密码进行登录

  10. def test_password_is_wrong(self):

  11. expect_reslut = 3

  12. actual_result = login('admin', '1234567').get('code')

  13. self.assertEqual(expect_reslut, actual_result)

  14. # case3 : 输入正确的用户名和空的密码进行登录

  15. def test_password_is_null(self):

  16. expect_reslut = 2

  17. actual_result = login('admin', '').get('code')

  18. self.assertEqual(expect_reslut, actual_result)

可以看到,三条用例对应三个测试方法,虽然清晰 ,代码每个方法中的代码几乎是相同的。

那如果用参数化实现的代码是什么呢 ? 可以看下面的这段代码 :

  1. class TestLogin(unittest.TestCase):

  2. @parameterized.expand(cases)

  3. def test_login(self,expect_result,username,password):

  4. actual_result = login(username,password).get('code')

  5. self.assertEqual(expect_result,actual_result)

以上代码只有一条用例 ,不管这个功能有几条都能执行 。

通过上面两种形式的比较可以看出 :为什么要进行数据参数化呢 ?其实就是降低代码冗余、提高代码复用度 ,将主要编写测试用例的时间转化为编写测试数据上来 。

1.3.如何进行数据参数化

在代码中实现数据参数化都需要借助于外部工具 ,比如专门用于unittest的ddt , 既支持unittest、也支持pytest的parameterized ,专门在pytest中使用的fixture.params .

参数化工具

支持测试框架

备注

ddt

unittest

第三方包,需要下载安装

parameterized

nose,unittest,pytest

第三方包,需要下载安装

@pytest.mark.parametrize

pytest

本身属于pytest中的功能

@pytest.fixture(params=[])

pytest

本身属于pytest中的功能

以上实现数据参数化的工具有两个共同点:

  • 都能实现数据参数化
  • 都时装饰器来作用于测试用例脚本 。

2.模块介绍

1.下载安装 :

  1. # 下载

  2. pip install parameterized

  3. # 验证 :

  4. pip show parameterized

2.导包

  1. # 直接导入parameterized类

  2. from parameterized import parameterized

3.官网示例

@parameterized 和 @parameterized.expand 装饰器接受列表 或元组或参数(...)的可迭代对象,或返回列表或 可迭代:

  1. from parameterized import parameterized, param

  2. # A list of tuples

  3. @parameterized([

  4. (2, 3, 5),

  5. (3, 5, 8),

  6. ])

  7. def test_add(a, b, expected):

  8. assert_equal(a + b, expected)

  9. # A list of params

  10. @parameterized([

  11. param("10", 10),

  12. param("10", 16, base=16),

  13. ])

  14. def test_int(str_val, expected, base=10):

  15. assert_equal(int(str_val, base=base), expected)

  16. # An iterable of params

  17. @parameterized(

  18. param.explicit(*json.loads(line))

  19. for line in open("testcases.jsons")

  20. )

  21. def test_from_json_file(...):

  22. ...

  23. # A callable which returns a list of tuples

  24. def load_test_cases():

  25. return [

  26. ("test1", ),

  27. ("test2", ),

  28. ]

  29. @parameterized(load_test_cases)

  30. def test_from_function(name):

  31. ...

请注意,使用迭代器或生成器时,将加载所有项 在测试运行开始之前放入内存(我们显式执行此操作以确保 生成器在多进程或多线程中只耗尽一次 测试环境)。

@parameterized装饰器可以使用测试类方法,并且可以独立使用 功能:

  1. from parameterized import parameterized

  2. class AddTest(object):

  3. @parameterized([

  4. (2, 3, 5),

  5. ])

  6. def test_add(self, a, b, expected):

  7. assert_equal(a + b, expected)

  8. @parameterized([

  9. (2, 3, 5),

  10. ])

  11. def test_add(a, b, expected):

  12. assert_equal(a + b, expected)

@parameterized.expand可用于生成测试方法 无法使用测试生成器的情况(例如,当测试 类是单元测试的一个子类。测试用例):

  1. import unittest

  2. from parameterized import parameterized

  3. class AddTestCase(unittest.TestCase):

  4. @parameterized.expand([

  5. ("2 and 3", 2, 3, 5),

  6. ("3 and 5", 3, 5, 8),

  7. ])

  8. def test_add(self, _, a, b, expected):

  9. assert_equal(a + b, expected)

将创建测试用例:

  1. $ nosetests example.py

  2. test_add_0_2_and_3 (example.AddTestCase) ... ok

  3. test_add_1_3_and_5 (example.AddTestCase) ... ok

  4. ----------------------------------------------------------------------

  5. Ran 2 tests in 0.001s

  6. OK

请注意,@parameterized.expand 的工作原理是在测试上创建新方法 .class。如果第一个参数是字符串,则该字符串将添加到末尾 的方法名称。例如,上面的测试用例将生成方法test_add_0_2_and_3和test_add_1_3_and_5。

@parameterized.expand 生成的测试用例的名称可以是 使用 name_func 关键字参数进行自定义。该值应 是一个接受三个参数的函数:testcase_func、param_num、 和参数,它应该返回测试用例的名称。testcase_func是要测试的功能,param_num将是 参数列表中测试用例参数的索引,参数(参数的实例)将是将使用的参数。

  1. import unittest

  2. from parameterized import parameterized

  3. def custom_name_func(testcase_func, param_num, param):

  4. return "%s_%s" %(

  5. testcase_func.__name__,

  6. parameterized.to_safe_name("_".join(str(x) for x in param.args)),

  7. )

  8. class AddTestCase(unittest.TestCase):

  9. @parameterized.expand([

  10. (2, 3, 5),

  11. (2, 3, 5),

  12. ], name_func=custom_name_func)

  13. def test_add(self, a, b, expected):

  14. assert_equal(a + b, expected)

将创建测试用例:

  1. $ nosetests example.py

  2. test_add_1_2_3 (example.AddTestCase) ... ok

  3. test_add_2_3_5 (example.AddTestCase) ... ok

  4. ----------------------------------------------------------------------

  5. Ran 2 tests in 0.001s

  6. OK

param(...) 帮助程序类存储一个特定测试的参数 箱。它可用于将关键字参数传递给测试用例:

  1. from parameterized import parameterized, param

  2. @parameterized([

  3. param("10", 10),

  4. param("10", 16, base=16),

  5. ])

  6. def test_int(str_val, expected, base=10):

  7. assert_equal(int(str_val, base=base), expected)

如果测试用例具有文档字符串,则该测试用例的参数将为 附加到文档字符串的第一行。可以控制此行为 doc_func参数:

  1. from parameterized import parameterized

  2. @parameterized([

  3. (1, 2, 3),

  4. (4, 5, 9),

  5. ])

  6. def test_add(a, b, expected):

  7. """ Test addition. """

  8. assert_equal(a + b, expected)

  9. def my_doc_func(func, num, param):

  10. return "%s: %s with %s" %(num, func.__name__, param)

  11. @parameterized([

  12. (5, 4, 1),

  13. (9, 6, 3),

  14. ], doc_func=my_doc_func)

  15. def test_subtraction(a, b, expected):

  16. assert_equal(a - b, expected)

  17. $ nosetests example.py

  18. Test addition. [with a=1, b=2, expected=3] ... ok

  19. Test addition. [with a=4, b=5, expected=9] ... ok

  20. 0: test_subtraction with param(*(5, 4, 1)) ... ok

  21. 1: test_subtraction with param(*(9, 6, 3)) ... ok

  22. ----------------------------------------------------------------------

  23. Ran 4 tests in 0.001s

  24. OK

最后@parameterized_class参数化整个类,使用 属性列表或将应用于 .class

  1. from yourapp.models import User

  2. from parameterized import parameterized_class

  3. @parameterized_class([

  4. { "username": "user_1", "access_level": 1 },

  5. { "username": "user_2", "access_level": 2, "expected_status_code": 404 },

  6. ])

  7. class TestUserAccessLevel(TestCase):

  8. expected_status_code = 200

  9. def setUp(self):

  10. self.client.force_login(User.objects.get(username=self.username)[0])

  11. def test_url_a(self):

  12. response = self.client.get('/url')

  13. self.assertEqual(response.status_code, self.expected_status_code)

  14. def tearDown(self):

  15. self.client.logout()

  16. @parameterized_class(("username", "access_level", "expected_status_code"), [

  17. ("user_1", 1, 200),

  18. ("user_2", 2, 404)

  19. ])

  20. class TestUserAccessLevel(TestCase):

  21. def setUp(self):

  22. self.client.force_login(User.objects.get(username=self.username)[0])

  23. def test_url_a(self):

  24. response = self.client.get("/url")

  25. self.assertEqual(response.status_code, self.expected_status_code)

  26. def tearDown(self):

  27. self.client.logout()

@parameterized_class装饰器接受class_name_func论点, 它控制由 @parameterized_class 生成的参数化类的名称:

  1. from parameterized import parameterized, parameterized_class

  2. def get_class_name(cls, num, params_dict):

  3. # By default the generated class named includes either the "name"

  4. # parameter (if present), or the first string value. This example shows

  5. # multiple parameters being included in the generated class name:

  6. return "%s_%s_%s%s" %(

  7. cls.__name__,

  8. num,

  9. parameterized.to_safe_name(params_dict['a']),

  10. parameterized.to_safe_name(params_dict['b']),

  11. )

  12. @parameterized_class([

  13. { "a": "hello", "b": " world!", "expected": "hello world!" },

  14. { "a": "say ", "b": " cheese :)", "expected": "say cheese :)" },

  15. ], class_name_func=get_class_name)

  16. class TestConcatenation(TestCase):

  17. def test_concat(self):

  18. self.assertEqual(self.a + self.b, self.expected)

  19. $ nosetests -v test_math.py

  20. test_concat (test_concat.TestConcatenation_0_hello_world_) ... ok

  21. test_concat (test_concat.TestConcatenation_0_say_cheese__) ... ok

使用单个参数

如果测试函数只接受一个参数并且该值不可迭代, 然后可以提供值列表,而无需将每个值包装在 元:

 
  1. @parameterized([1, 2, 3])

  2. def test_greater_than_zero(value):

  3. assert value > 0

但请注意,如果单个参数可迭代的(例如列表或 元组),那么它必须包装在元组、列表或 param(...) 装饰器中:

  1. @parameterized([

  2. ([1, 2, 3], ),

  3. ([3, 3], ),

  4. ([6], ),

  5. ])

  6. def test_sums_to_6(numbers):

  7. assert sum(numbers) == 6

虽然看似以上功能支持的挺多 ,但其实真正用的不多 ,因为它跟框架有很大关系的 。具体说明下 :

总结:

  • 它支持nose是最好的 . 如果你的自动化中使用nose,那么以上功能基本都能用到 。
  • 如果你用的测试框架是unittest ,你只能用到它的expand()这个函数 ,不过有这个函数也就够了 。
  • 如果你用的测试框架是pytest , 它支持了Pytest3的版本,再高版本的就不支持了,同时pytest也有自己的参数化工具,一般也不用它了。

3.项目实践

通过数据参数胡重新编写登录测试用例 ,将以前yaml中的登录用例数据转化为paramterized的数据格式 ,它的数据格式要求为:[(),(),()] . 所以,编写测试用例的数据就变为了以下的代码 。

  1. # 将登录数据转化为paramterize所识别的格式。

  2. def get_data():

  3. yaml_path = get_file_path('login.yaml') # 获取login.yaml的全路径

  4. result = read_yaml(yaml_path) # 转化为python对象

  5. login_data = result.get('login') # 获取字典中login的值

  6. logger.debug("登录结果:{}".format(login_data))

  7. return (login_data) # 获取字典中login的值

  8. @allure.epic("vshop")

  9. @allure.story("登录")

  10. class TestLogin(unittest.TestCase):

  11. # case1 : 测试登录功能

  12. @parameterized.expand(get_data())

  13. def test_login(self,case_name,username,password,code,message):

  14. logger.info("从参数化获取的数据:{}|{}|{}|{}|{}".format(case_name,username,password,code,message))

  15. with allure.step("执行用例:{},输入用户名:{},输入密码:{}".format(case_name,username,password)):

  16. login_result = login(username,password)

  17. self.assertEqual(code, login_result.get('errno'))

  18. self.assertEqual(message, login_result.get('errmsg'))

这样的话,我们只编写了一条测试用例 ,但是在测试数据中有几条数据 ,都可以正常运行 。

 

行动吧,在路上总比一直观望的要好,未来的你肯定会感 谢现在拼搏的自己!如果想学习提升找不到资料,没人答疑解惑时,请及时加入扣群: 455787643,里面有各种软件测试+开发资料和技术可以一起交流学习哦。

总结:感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

相关文章:

python实现自动化测试框架如何进行数据参数化?这个包可以了解下

1.数据参数化介绍 只要你是负责编写自动化测试脚本的,数据参数化这个思想你就肯定会用 ,数据参数化的工具你肯定的懂一些 ,因为它能大大的提高我们自动化脚本编写效率 。 1.1什么是数据参数化 所谓的数据参数化 ,是指所执行的测…...

面试题:Redis和MySql数据库如何保持数据一致性?

前提引入: 在高并发的场景下,大量的请求直接访问Mysql很容易造成性能问题。所以,我们都会用Redis来做数据的缓存,削减对数据库的请求。但是,Mysql和Redis是两种不同的数据库,如何保证不同数据库之间数据的一…...

直流遥控器 继电器8-10V应用 降压恒压SL3036电源芯片

在现代电子设备中,电源的稳定性和可靠性对于设备的正常运行至关重要。特别是在直流遥控器这类设备中,由于其需要长时间稳定运行且对电压稳定性要求较高,因此选择一款合适的电源芯片显得尤为重要。本文将重点介绍SL3036电源芯片在直流遥控器继…...

论文Abstract怎么写

摘要是你要写的最后一项内容 步骤 首先先通读自己的文章,清楚自己写的文章是研究型还是技术型,适合描述性的摘要还是知识性。 描述性摘要内含研究目的、目标及方向等,不讲研究结果。字数大约100-200字。知识性摘要则包含研究结果&#xff0c…...

PS系统教程19

渐变与照片调色 增加色彩背景新建图层选好渐变拉选图片渐变 与图层模式结合 也可以变换颜色 看起来比较自然,因为是与人物结合起来 也可以选择系统里面的一些色调 可以进行多次调试...

Excel函数之MAP

MAP 语法 MAP(array, [arrar2], ……, lambda(value,[value2], ……, calculation)) array:需要进行映射的数组,可以有多个 注:多个数组的形状大小尽可能保持一致,否则将出现错误值 value:数组中的每个值,每次取一个值,每个 array 按顺序对应一个 value calculation:…...

在2024年WWDC大会上,苹果宣布了其全新的“Apple Intelligence”AI功能以及ISO18功能

以下是一些主要的新增功能: Apple WWDC 2024开发者大会6月11日凌晨在总部Apple Park举行 1.智能照片编辑: 照片:AI驱动的照片润饰功能,可以根据用户描述生成自定义表情符号​ 2.Safari浏览助手: Safari:AI助手能够总…...

解决linux jenkins要求JDK版本与项目版本JDK不一致问题

背景–问题描述: 新入职公司,交接人说jenkins运行有问题,现在都是手动发布,具体原因让我自己看(笑哭)。我人都蒙了,测试环境都手动发布,那不是麻烦的要死! 接手后&am…...

推荐一款WPF绘图插件OxyPlot

开始 使用 NuGet 包管理器添加对 OxyPlot 的引用(如果要使用预发布包,请参阅下面的详细信息)向用户界面添加PlotView在代码中创建一个PlotModel绑定到你的属性PlotModelModelPlotView 例子 您可以在代码存储库的文件夹中找到示例。/Source/Ex…...

普通表在线重定义为分区表

普通表在线转换成分区表示例 源表表结构如下: CREATE TABLE EDC_SEPERATOR ( SEPERATOR_ID NUMBER(15) NOT NULL, EQUIPMENTINFO NVARCHAR2(20), RECORD NVARCHAR2(50), TITLE NVARCHAR2(50), ID NVARCHAR2(50), TE…...

自动驾驶场景下TCP协议参数优化调整案例分享

RTT 往返时间,从tcp协议栈决定发包,到收到回包的时间。 包含本地驱动,网卡硬件,网线,交换机,收包方处理的耗时。需注意如果开了delayed ack,协议栈未做特殊处理(默认没做&#xff…...

奇思妙想:多头RAG

大模型技术论文不断,每个月总会新增上千篇。本专栏精选论文重点解读,主题还是围绕着行业实践和工程量产。若在某个环节出现卡点,可以回到大模型必备腔调或者LLM背后的基础模型新阅读。而最新科技(Mamba,xLSTM,KAN)则提…...

H323 截包分析辅流问题

辅流问题(h264\h264hp\h265) 终端1 : 192.168.1.1 入会发送辅流 终端2 : 192.168.1.2 入会接收辅流 问题 : 终端2不显示辅流 1、筛选 h245 h225 协议 分别筛选以下IP进行查看截包内容 (h225 || h245) && …...

低成本和颜值兼顾的 HomeLab 设备:HPE MicroServer Gen10(二)

本篇文章,继续分享另外一台端午假期折腾的设备,HP MicroServer Gen10 一代。同样分享下我的折腾思路,希望能够帮助到有类似需求的你。 写在前面 Gen10 “标准版”(第一代)和 Plus 版本设计风格一致,同样颜…...

面试题:ArrayList和LinkedList的区别

ArrayList和LinkedList都是Java中实现List接口的集合类,用于存储和操作对象列表,但它们在内部数据结构、性能特性和适用场景上有所不同: 1.内部数据结构: ArrayList:基于动态数组实现。这意味着它在内存中是连续存储…...

【王树森】深度强化学习(DRL)学习笔记

目录 第一部分:基础知识1.机器学习基础2.蒙特卡洛估计3.强化学习基础知识3.1 马尔科夫决策过程马尔可夫决策过程(Markov decision process,MDP)智能体环境状态状态空间动作动作空间奖励状态转移状态转移概率 3.2 策略策略定义 3.3…...

LLM应用实战:当图谱问答(KBQA)集成大模型(三)

1. 背景 最近比较忙(也有点茫),本qiang~想切入多模态大模型领域,所以一直在潜心研读中... 本次的更新内容主要是响应图谱问答集成LLM项目中反馈问题的优化总结,对KBQA集成LLM不熟悉的客官可以翻翻之前的文章《LLM应用实战:当KBQ…...

Django框架中Ajax GET与POST请求的实战应用

系列文章目录 以下几篇侧重点为JavaScript内容0.0 JavaScript入门宝典:核心知识全攻略(上)JavaScript入门宝典:核心知识全攻略(下)Django框架中Ajax GET与POST请求的实战应用VSCode调试揭秘:L…...

web前端怎么挣钱, 提升技能,拓宽就业渠道

web前端怎么挣钱 在当今数字化时代,Web前端技术已成为互联网行业中不可或缺的一部分。越来越多的人选择投身于这个领域,希望能够通过掌握前端技术来实现自己的职业发展和经济收益。那么,Web前端如何挣钱呢?接下来,我们…...

基于Python的信号处理(包络谱,低通、高通、带通滤波,初级特征提取,机器学习,短时傅里叶变换)及轴承故障诊断探索

Python是一种广泛使用的解释型、高级和通用的编程语言,众多的开源科学计算软件包都提供了Python接口,如计算机视觉库OpenCV、可视化工具库VTK等。Python专用计算扩展库,如NumPy、SciPy、matplotlab、Pandas、scikit-learn等。 开发工具上可用…...

大型语言模型智能体(LLM Agent)在实际使用的五大问题

在这篇文章中,我将讨论人们在将代理系统投入生产过程中经常遇到的五个主要问题。我将尽量保持框架中立,尽管某些问题在特定框架中更加常见。 1. 可靠性问题 可靠性是所有代理系统面临的最大问题。很多公司对代理系统的复杂任务持谨慎态度,因…...

C语言内存管理

1.进程的内存分布 练习&#xff1a;编写一个程序&#xff0c;测试栈空间的大小 #include<stdio.h>#define SIZE 1024*1024*7void main (void) {char buf[SIZE];buf[SIZE-1] 100;printf("%d\n",buf[SIZE-1]); }如果SIZE 大小超过8M(102410248)&#xff0c;…...

AD24设计步骤

一、元件库的创建 1、AD工程创建 然后创建原理图、PCB、库等文件 2、电阻容模型的创建 注意&#xff1a;防止管脚时设置栅格大小为100mil&#xff0c;防止线段等可以设置小一点,快捷键vgs设置栅格大小。 1.管脚的设置 2.元件的设置 3、IC类元件的创建 4、排针类元件模型创建…...

基于MBD的大飞机模块化广域协同研制

引言 借鉴国外航空企业先进经验&#xff0c;在国内&#xff0c;飞机型号的研制通常采用基于模型定义&#xff08;MBD&#xff09;的三维数模作为唯一的设计制造协同数据源&#xff0c;从而有效减少了设计和制造部门之间的模型沟通成本和重构所需的时间&#xff0c;也减少或避免…...

鸿蒙轻内核M核源码分析系列二十 Newlib C

LiteOS-M内核LibC实现有2种&#xff0c;可以根据需求进行二选一&#xff0c;分别是musl libC和newlibc。本文先学习下Newlib C的实现代码。文中所涉及的源码&#xff0c;均可以在开源站点https://gitee.com/openharmony/kernel_liteos_m 获取。 使用Musl C库的时候&#xff0c…...

力扣1818.绝对差值和

力扣1818.绝对差值和 把nums1拷贝复制一份 去重排序 对于每个nums2都找到差距最小的那个数(二分) 作差求最大可优化差值去重排序可以直接用set 自动去重排序了 const int N 1e97;class Solution {public:int minAbsoluteSumDiff(vector<int>& nums1, vector<i…...

矩阵练习2

48.旋转图像 规律&#xff1a; 对于矩阵中第 i行的第 j 个元素&#xff0c;在旋转后&#xff0c;它出现在倒数第i 列的第 j 个位置。 matrix[col][n−row−1]matrix[row][col] 可以使用辅助数组&#xff0c;如果不想使用额外的内存&#xff0c;可以用一个临时变量 。 还可以通…...

2024海南省大数据教师培训-Hadoop集群部署

前言 本文将详细介绍Hadoop分布式计算框架的来源&#xff0c;架构和应用场景&#xff0c;并附上最详细的集群搭建教程&#xff0c;能更好的帮助各位老师和同学们迅速了解和部署Hadoop框架来进行生产力和学习方面的应用。 一、Hadoop介绍 Hadoop是一个开源的分布式计算框架&…...

力扣算法题:将数字变为0的操作次数--多语言实现

无意间看到&#xff0c;力扣存算法代码居然还得升级vip。。。好吧&#xff0c;我自己存吧 golang&#xff1a; func numberOfSteps(num int) int {steps : 0for num > 0 {if num%2 0 {num / 2} else {num - 1}steps}return steps } javascript: /*** param {number} num…...

vue前段处理时间格式,设置开始时间为00:00:00,设置结束时间为23:59:59

在Vue开发中&#xff0c;要在前端控制日期时间选择器的时间范围&#xff0c;可以通过以下方式实现&#xff1a; 使用beforeDestroy生命周期钩子函数来处理时间范围&#xff1a; 在Vue组件中&#xff0c;可以监听日期时间选择器的变化&#xff0c;在选择开始日期时&#xff0c;自…...

互联网网站seo优化/广州网站设计制作

Rsync安装配置昨天由于部门研发同事要做个小项目&#xff0c;要我提供一份rsync的安装配置文档&#xff0c;就简单了写了份&#xff0c;顺便发出来了。1&#xff0c; 测试环境&#xff1a;CentOS release 5.8 2.6.18-308.el5 x86_64IP_S: 192.168.104.137IP_C: 192.168.…...

wordpress qoob/seo算法

使用场景&#xff1a;在操作应用时常见toast弹框&#xff0c;通过toast弹框信息的获取判断当前的某个操作是否成功 引用的包&#xff1a;from selenium.webdriver.support import expected_conditions as EC,\expected_conditions from selenium.webdriver.common.by import By…...

专业做外挂的网站/百度信息流广告投放

版本信息&#xff1a;SDE9.3、ORACLE11g1、SDE锁表检查处理1.1、查询并删除锁表进程(以sys或者system用户运行)select t1.username, t.object_id, t.session_id, t1.serial#,t.oracle_username,t.os_user_name, t.process from v$locked_object t,v$session t1 where t.session…...

如何租用服务器做网站/长安seo排名优化培训

MPI简介在程序中&#xff0c;不同的进程需要相互的数据交换&#xff0c;特别是在科学计算中&#xff0c;需要大规模的计算与数据交换&#xff0c;集群可以很好解决单节点计算力不足的问题&#xff0c;但在集群中大规模的数据交换是很耗费时间的&#xff0c;因此需要一种在多节点…...

推荐一下做图文的网站/短视频营销策略有哪些

点击蓝字关注我们哟~1、移动&#xff1a;图形在平面上的移动&#xff0c;图形本身的大小和形状不发生改变&#xff0c;分析移动规律时要找准移动的方向和距离。(1)上下、左右&#xff1b;折返、循环(2)顺、逆时针&#xff1a;就近原则、平均原则(不一定到顶端才转弯、十六格注意…...

不备案 国内网站/自己怎么创建网站

今天给大家分享在VC6.0环境下编写C语言程序的基本步骤&#xff0c;为初学者打开学习C语言的第一道门。具体步骤如下(如果需要软件资源&#xff0c;可以留言)&#xff1a;1&#xff09;新建工作区依次点击 文件--新建--工作区 或是CtrlN&#xff0c;新建工作区&#xff0c;弹出如…...