Python单元测试之道:从入门到精通的全面指南

news2024/11/20 15:19:10

在这篇文章中,我们会深入探讨Python单元测试的各个方面,包括它的基本概念、基础知识、实践方法、高级话题,如何在实际项目中进行单元测试,单元测试的最佳实践,以及一些有用的工具和资源

一、单元测试重要性

测试是软件开发中不可或缺的一部分,它能够帮助我们保证代码的质量,减少bug,提高系统的稳定性。在各种测试方法中,单元测试由于其快速、有效的特性,特别受到开发者们的喜欢。本文将全面介绍Python中的单元测试。

1.1 为什么单元测试重要?

在我们写代码的过程中,我们可能会遇到各种各样的问题,而这些问题如果没有得到妥善的处理,往往会在项目上线后变成难以预见的bug。这些bug不仅会影响用户的使用体验,还可能带来严重的经济损失。因此,单元测试就显得尤为重要,它可以帮助我们在代码开发的过程中就发现和解决问题,避免问题的积累和放大。

例如,我们在编写一个简单的加法函数时:

def add(x, y):
    return x + y

我们可以通过编写一个简单的单元测试,来保证这个函数的功能:

import unittest

class TestAdd(unittest.TestCase):
    def test_add(self):
        self.assertEqual(add(1, 2), 3)

通过运行这个测试,我们可以验证add函数是否正常工作。

1.2 单元测试在Python中的应用

Python有一个内置的unittest模块,我们可以使用它来进行单元测试。此外,Python社区也提供了一些其他的单元测试工具,如pytestnose等。本文将主要介绍如何使用Python的unittest模块来进行单元测试。

在Python的开发过程中,良好的单元测试不仅可以帮助我们保证代码的质量,还可以作为文档,帮助其他开发者理解和使用我们的代码。因此,单元测试在Python的开发过程中占有非常重要的地位。

二、Python单元测试基础知识

在介绍单元测试的具体操作之前,我们需要对一些基础知识有所了解。在这一部分,我们将了解什么是单元测试,以及Python的unittest模块。

2.1 什么是单元测试?

单元测试(Unit Testing)是一种软件测试方法,它的目标是验证代码中各个独立的单元(通常是函数、方法或类)的行为是否符合我们的预期。单元测试有许多优点,如快速、反馈即时、易于定位问题等,是测试驱动开发(TDD)的重要组成部分。

例如,我们有一个函数用于求一个数字的平方:

def square(n):
    return n * n

我们可以写一个单元测试来验证这个函数是否能正常工作:

import unittest

class TestSquare(unittest.TestCase):
    def test_square(self):
        self.assertEqual(square(2), 4)
        self.assertEqual(square(-2), 4)
        self.assertEqual(square(0), 0)

这样,无论我们的代码在何时被修改,都可以通过运行这个单元测试来快速检查是否存在问题。

2.2 Python的unittest模块简介

Python的unittest模块是Python标准库中用于进行单元测试的模块,它提供了一套丰富的API供我们编写和运行单元测试。unittest模块的使用主要包括三个步骤:

  1. 导入unittest模块。
  2. 定义一个继承自unittest.TestCase的测试类,然后在这个类中定义各种测试方法(方法名以test_开头)。
  3. 在命令行中运行测试。

下面是一个简单的例子:

import unittest

class TestMath(unittest.TestCase):
    def test_add(self):
        self.assertEqual(1 + 1, 2)

    def test_subtract(self):
        self.assertEqual(3 - 2, 1)

if __name__ == '__main__':
    unittest.main()

在命令行中运行这个脚本,就会执行所有的测试方法,然后输出测试结果。

三、Python单元测试实践

了解了单元测试的基础知识后,我们将开始实践。在这一部分,我们将演示如何在Python中编写和运行单元测试。

3.1 如何写一个基本的单元测试?

在Python中,我们可以使用unittest模块来编写单元测试。一个基本的单元测试通常包含以下几个部分:

  1. 导入unittest模块。
  2. 定义一个继承自unittest.TestCase的测试类。
  3. 在这个测试类中定义各种测试方法(方法名以test_开头)。
  4. 在这些测试方法中使用unittest.TestCase的各种断言方法来检查被测代码的行为。

例如,我们有以下一个函数:


def divide(x, y):
    if y == 0:
        raise ValueError("Can not divide by zero!")
    return x / y

我们可以这样编写单元测试:

import unittest

class TestDivide(unittest.TestCase):
    def test_divide(self):
        self.assertEqual(divide(4, 2), 2)
        self.assertEqual(divide(-4, 2), -2)
        self.assertRaises(ValueError, divide, 4, 0)

if __name__ == '__main__':
    unittest.main()

在这个例子中,我们使用了unittest.TestCaseassertEqual方法和assertRaises方法来检查divide函数的行为。

3.2 测试用例、测试套件和测试运行器的概念和创建

unittest模块中,我们有以下几个重要的概念:

  • 测试用例(Test Case):一个测试用例就是一个完整的测试流程,包括测试前的准备环节、执行测试动作和测试后的清扫环节。在unittest模块中,一个测试用例就是一个unittest.TestCase的实例。
  • 测试套件(Test Suite):测试套件是一系列的测试用例或测试套件的集合。我们可以使用unittest.TestSuite类来创建测试套件。
  • 测试运行器(Test Runner):测试运行器是用来执行和控制测试的。我们可以使用unittest.TextTestRunner类来创建一个简单的文本测试运行器。

以下是一个例子:

import unittest

class TestMath(unittest.TestCase):
    # 测试用例
    def test_add(self):
        self.assertEqual(1 + 1, 2)

    def test_subtract(self):
        self.assertEqual(3 - 2, 1)

# 创建测试套件
suite = unittest.TestSuite()
suite.addTest(TestMath('test_add'))
suite.addTest(TestMath('test_subtract'))

# 创建测试运行器
runner = unittest.TextTestRunner()
runner.run(suite)

在这个例子中,我们创建了一个包含两个测试用例的测试套件,然后用一个文本测试运行器来执行这个测试套件。

3.3 使用setUp和tearDown处理测试前后的准备和清理工作

在编写单元测试时,我们经常需要在每个测试方法执行前后做一些准备和清理工作。例如,我们可能需要在每个测试方法开始前创建一些对象,然后在每个测试方法结束后销毁这些对象。我们可以在测试类中定义setUptearDown方法来实现这些功能。

import unittest

class TestDatabase(unittest.TestCase):
    def setUp(self):
        # 创建数据库连接
        self.conn = create_database_connection()

    def tearDown(self):
        # 关闭数据库连接
        self.conn.close()

    def test_insert(self):
        # 使用数据库连接进行测试
        self.conn.insert(...)

在这个例子中,我们在setUp方法中创建了一个数据库连接,在tearDown方法中关闭了这个数据库连接。这样,我们就可以在每个测试方法中使用这个数据库连接进行测试,而不需要在每个测试方法中都创建和销毁数据库连接。

四、Python单元测试高级话题

我们已经了解了Python单元测试的基本概念和使用方法。现在,我们将深入探讨一些高级话题,包括测试驱动开发(TDD)、模拟对象(Mocking)和参数化测试。

4.1 测试驱动开发(TDD)

测试驱动开发(Test-Driven Development,简称TDD)是一种软件开发方法,它强调在编写代码之前先编写单元测试。TDD的基本步骤是:

  1. 先写一个失败的单元测试。
  2. 编写代码,使得这个单元测试通过。
  3. 重构代码,使得代码更好。

TDD有助于我们保持代码的质量,也使得我们的代码更容易维护和修改。

4.2 模拟对象(Mocking)

在编写单元测试时,我们有时需要模拟一些外部的、不可控的因素,如时间、数据库、网络请求等。Python的unittest.mock模块提供了一种创建模拟对象的方法,我们可以用它来模拟外部的、不可控的因素。

例如,假设我们有一个函数,它会根据当前时间来决定返回什么结果:

import datetime

def get_greeting():
    current_hour = datetime.datetime.now().hour
    if current_hour < 12:
        return "Good morning!"
    elif current_hour < 18:
        return "Good afternoon!"
    else:
        return "Good evening!"

我们可以使用unittest.mock来模拟当前时间,以便测试这个函数:

import unittest
from unittest.mock import patch

class TestGreeting(unittest.TestCase):
    @patch('datetime.datetime')
    def test_get_greeting(self, mock_datetime):
        mock_datetime.now.return_value.hour = 9
        self.assertEqual(get_greeting(), "Good morning!")

        mock_datetime.now.return_value.hour = 15
        self.assertEqual(get_greeting(), "Good afternoon!")

        mock_datetime.now.return_value.hour = 20
        self.assertEqual(get_greeting(), "Good evening!")

if __name__ == '__main__':
    unittest.main()

在这个例子中,我们使用unittest.mock.patch来模拟datetime.datetime对象,然后设置其now方法的返回值。

4.3 参数化测试

参数化测试是一种单元测试技术,它允许我们使用不同的输入数据来运行相同的测试。在Python的unittest模块中,我们可以使用unittest.subTest上下文管理器来实现参数化测试。

以下是一个例子:

import unittest

class TestSquare(unittest.TestCase):
    def test_square(self):
        for i in range(-10, 11):
            with self.subTest(i=i):
                self.assertEqual(square(i), i * i)

if __name__ == '__main__':
    unittest.main()

在这个例子中,我们使用unittest.subTest上下文管理器来运行20个不同的测试,每个测试都使用不同的输入数据。

五、实战演练:Python单元测试的完整项目示例

在这一部分,我们将通过一个简单的项目来展示如何在实践中应用Python单元测试。我们将创建一个简单的“分数计算器”应用,它可以执行分数的加、减、乘、除运算。

5.1 创建项目

首先,我们创建一个新的Python项目,并在项目中创建一个fraction_calculator.py文件。在这个文件中,我们定义一个Fraction类,用来表示分数。这个类有两个属性:分子(numerator)和分母(denominator)。

# fraction_calculator.py

class Fraction:
    def __init__(self, numerator, denominator):
        if denominator == 0:
            raise ValueError("Denominator cannot be zero!")
        self.numerator = numerator
        self.denominator = denominator

5.2 编写单元测试

然后,我们创建一个test_fraction_calculator.py文件,在这个文件中,我们编写单元测试来测试Fraction类。

# test_fraction_calculator.py

import unittest
from fraction_calculator import Fraction

class TestFraction(unittest.TestCase):
    def test_create_fraction(self):
        f = Fraction(1, 2)
        self.assertEqual(f.numerator, 1)
        self.assertEqual(f.denominator, 2)

    def test_create_fraction_with_zero_denominator(self):
        with self.assertRaises(ValueError):
            Fraction(1, 0)

if __name__ == '__main__':
    unittest.main()

在这个测试类中,我们创建了两个测试方法:test_create_fraction测试正常创建分数,test_create_fraction_with_zero_denominator测试当分母为零时应抛出异常。

5.3 执行单元测试

最后,我们在命令行中运行test_fraction_calculator.py文件,执行单元测试。

python -m unittest test_fraction_calculator.py

如果所有的测试都通过,那么我们就可以有信心地说,我们的Fraction类是正确的。

5.4 扩展项目

当然,我们的项目还远远没有完成。Fraction类还需要添加许多功能,如加、减、乘、除运算,约简分数,转换为浮点数等。对于每一个新的功能,我们都需要编写相应的单元测试来确保其正确性。并且,我们也需要不断地运行这些单元测试,以确保我们的修改没有破坏已有的功能。

单元测试是一个持续的过程,而不是一次性的任务。只有不断地编写和运行单元测试,我们才能保证我们的代码的质量和可靠性。

六、Python单元测试的最佳实践

在实际编写和执行Python单元测试的过程中,有一些最佳实践可以帮助我们提高工作效率,并保证测试的质量和可靠性。

6.1 始终先编写测试

按照测试驱动开发(TDD)的原则,我们应该先编写测试,然后再编写能通过测试的代码。这样可以帮助我们更清晰地理解我们要实现的功能,同时也能保证我们的代码是可测试的。

6.2 保持测试的独立性

每个测试都应该是独立的,不依赖于其他测试。如果测试之间有依赖关系,那么一个测试失败可能会导致其他测试也失败,这会使得测试结果难以理解,也会使得测试更难维护。

6.3 测试所有可能的情况

我们应该尽可能地测试所有可能的情况,包括正常情况、边界情况和异常情况。例如,如果我们有一个函数,它接受一个在0到100之间的整数作为参数,那么我们应该测试这个函数在参数为0、50、100和其他值时的行为。

6.4 使用模拟对象

在测试涉及到外部系统(如数据库、网络服务等)的代码时,我们可以使用模拟对象(Mocking)来代替真实的外部系统。这样可以使得测试更快、更稳定,并且更易于控制。

6.5 定期运行测试

我们应该定期运行我们的测试,以确保我们的代码没有被破坏。一种常见的做法是在每次提交代码之前运行测试。此外,我们还可以使用持续集成(Continuous Integration)工具,如Jenkins、Travis CI等,来自动运行我们的测试。

6.6 使用代码覆盖率工具

代码覆盖率是一个度量标准,用来表示我们的测试覆盖了多少代码。我们可以使用代码覆盖率工具,如coverage.py,来度量我们的代码覆盖率,并努力提高这个指标。但是,请记住,代码覆盖率并不能保证我们的测试的质量和完整性。它只是一个工具,我们不能过分依赖它。

# 运行代码覆盖率工具的示例
# 在命令行中输入以下命令:

$ coverage run --source=. -m unittest discover
$ coverage report

以上的命令将首先运行你的所有单元测试,并收集代码覆盖率信息。然后,它将显示一个代码覆盖率报告,这个报告将告诉你哪些代码被测试覆盖了,哪些代码没有被覆盖。

七、工具和资源

在进行Python单元测试时,有一些工具和资源可以帮助我们提高效率和质量。

7.1 Python内置的unittest模块

Python内置的unittest模块是一个强大的单元测试框架,提供了丰富的断言方法、测试套件、测试运行器等功能。如果你想要进行单元测试,unittest模块是一个很好的开始。

# unittest模块的基本使用
import unittest

class TestMyFunction(unittest.TestCase):
    def test_add(self):
        self.assertEqual(add(1, 2), 3)

if __name__ == '__main__':
    unittest.main()

7.2 pytest

pytest是一个流行的Python测试框架,比unittest更简洁,更强大。它不仅可以用于单元测试,还可以用于功能测试、集成测试等。

# pytest的基本使用
def test_add():
    assert add(1, 2) == 3

7.3 mock

mock模块可以帮助你创建模拟对象,以便在测试中替代真实的对象。这对于测试依赖于外部系统或难以构造的对象的代码非常有用。

# mock模块的基本使用
from unittest.mock import Mock

# 创建一个模拟对象
mock = Mock()
# 设置模拟对象的返回值
mock.return_value = 42
# 使用模拟对象
assert mock() == 42

7.4 coverage.py

coverage.py是一个代码覆盖率工具,可以帮助你找出哪些代码没有被测试覆盖。

# coverage.py的基本使用
coverage run --source=. -m unittest discover
coverage report

7.5 Python Testing

Python Testing是一个关于Python测试的网站,提供了许多有关Python测试的教程、工具、书籍和其他资源。

希望通过本文,你对Python单元测试有了更深入的理解和应用。单元测试是软件开发过程中非常重要的一环,正确地进行单元测试可以帮助我们提高代码质量,发现和修复问题,以及提高开发效率。Python提供了一系列强大的工具来进行单元测试,这些工具能够帮助我们编写更好的单元测试。

在编写单元测试的过程中,我们不仅可以发现和修复问题,还可以深入理解我们的代码和业务逻辑,提高我们的编程技能。

如果你对Python感兴趣,想要学习python,这里给大家分享一份Python全套学习资料,都是我自己学习时整理的,希望可以帮到你,一起加油!

😝有需要的小伙伴,可以点击下方链接免费领取或者V扫描下方二维码免费领取🆓
Python全套学习资料

在这里插入图片描述

1️⃣零基础入门

① 学习路线

对于从来没有接触过Python的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
在这里插入图片描述

② 路线对应学习视频

还有很多适合0基础入门的学习视频,有了这些视频,轻轻松松上手Python~
在这里插入图片描述

③练习题

每节视频课后,都有对应的练习题哦,可以检验学习成果哈哈!
在这里插入图片描述

2️⃣国内外Python书籍、文档

① 文档和书籍资料

在这里插入图片描述

3️⃣Python工具包+项目源码合集

①Python工具包

学习Python常用的开发软件都在这里了!每个都有详细的安装教程,保证你可以安装成功哦!
在这里插入图片描述

②Python实战案例

光学理论是没用的,要学会跟着一起敲代码,动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。100+实战案例源码等你来拿!
在这里插入图片描述

③Python小游戏源码

如果觉得上面的实战案例有点枯燥,可以试试自己用Python编写小游戏,让你的学习过程中增添一点趣味!
在这里插入图片描述

4️⃣Python面试题

我们学会了Python之后,有了技能就可以出去找工作啦!下面这些面试题是都来自阿里、腾讯、字节等一线互联网大厂,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
在这里插入图片描述
在这里插入图片描述

5️⃣Python兼职渠道

而且学会Python以后,还可以在各大兼职平台接单赚钱,各种兼职渠道+兼职注意事项+如何和客户沟通,我都整理成文档了。
在这里插入图片描述

上述所有资料 ⚡️ ,朋友们如果有需要的,可以扫描下方👇👇👇二维码免费领取🆓
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1263522.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ELk部署,保姆级教学超详细!!!

Elk&#xff08;Elasticsearch, Logstash, Kibana&#xff09;是一套日志收集、存储和展示方案&#xff0c;是由Elastic公司开发的开源软件组合。 Elasticsearch&#xff1a;是一个分布式的搜索和分析引擎。它能够处理大量的数据&#xff0c;并提供快速、准确的搜索结果&#x…

在线 SQL 模拟器SQL Fiddle使用简介

在线 SQL 模拟器SQL Fiddle使用简介 有时候&#xff0c;我们想去验证 SQL语句&#xff0c;却缺少数据库环境&#xff0c;那该怎么办呢&#xff1f; 这时候在线 SQL 模拟器就有了用武之地。SQL 模拟器免安装&#xff0c;可以在网页直接运行 SQL 。 SQL Fiddle 支持 MySQL、Orac…

Stable Diffusion绘画系列【4】:可爱盲盒风人物

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 《------往期经典推…

数据结构——链式二叉树的实现(详解)

呀哈喽。我是结衣。 不知道大家的递归学到怎么样呢&#xff1f;如果大家的递归功底不是很好&#xff0c;那么我相信在学完这篇文章后大家一定会对递归有一个更深层次的了解的。 构造链式二叉树 在学习二叉树的基本操作前&#xff0c;需先要创建一棵二叉树&#xff0c;然后才能…

国标GB28181安防监控平台EasyCVR周界入侵AI算法检测方案

在城市管理和公共安全领域&#xff0c;安全视频监控的重要性日益凸显。AI视频智能分析平台基于深度学习和计算机视觉技术&#xff0c;利用AI入侵算法&#xff0c;能够实时、精准地监测周界入侵行为。 TSINGSEE青犀在视频监控及AI视频智能分析领域拥有深厚的技术积累和丰富的实…

2020年3月25日 Go生态洞察:Go、Go社区与疫情大流行

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

2024年最受欢迎的项目管理工具盘点

十大项目管理系统包括&#xff1a;1.产品研发项目管理工具&#xff1a;PingCode&#xff1b;2.通用项目协作工具&#xff1a;Worktile&#xff1b;3.开源项目管理系统&#xff1a;Redmine&#xff1b;4.IT/敏捷项目管理系统&#xff1a;Jira&#xff1b;5.免费个人项目管理&…

java基础进阶-线程池

1、线程池 线程池就是一个可以复用线程的技术。 2、应用场景 用户每发起一个请求&#xff0c;后台就需要创建一个新线程来处理&#xff0c;下次新任务来了肯定又要创建新线程处理的&#xff0c;而创建新线程的开销是很大的&#xff0c;并且请求过多时&#xff0c;肯定会产生大…

2023年【起重机械指挥】考试题库及起重机械指挥考试资料

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2023年【起重机械指挥】考试题库及起重机械指挥考试资料&#xff0c;包含起重机械指挥考试题库答案和解析及起重机械指挥考试资料练习。安全生产模拟考试一点通结合国家起重机械指挥考试最新大纲及起重机械指挥考试真…

OpenSSL 使用AES对文件加解密

AES&#xff08;Advanced Encryption Standard&#xff09;是一种对称加密算法&#xff0c;它是目前广泛使用的加密算法之一。AES算法是由美国国家标准与技术研究院&#xff08;NIST&#xff09;于2001年发布的&#xff0c;它取代了原先的DES&#xff08;Data Encryption Stand…

设计师福利!2024在线图标设计网站推荐,不容错过的宝藏!

在当今竞争激烈的商业环境中&#xff0c;公司或个人品牌的视觉识别元素已经成为区分你和竞争对手的关键因素之一。一个独特而引人注目的标志可以深深扎根于人们的心中&#xff0c;并在消费者心中建立一个强烈的品牌印象。如果你正在寻找合适的工具来创建或改进你的标志&#xf…

Nginx系列-正向代理和反向代理

Nginx系列-正向代理和反向代理 文章目录 Nginx系列-正向代理和反向代理1. 三个对象2. 两种场景代理2.1. 正向代理2.2. 反向代理 3. 两种场景的对比3.1 为什么叫做反向代理3.2 正向代理和反向代理的作用 1. 三个对象 客户端&#xff1a;发出请求到代理&#xff0c;并接收代理的…

2019年11月20日 Go生态洞察:Go开发者调查启动

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

1128. 等价多米诺骨牌对的数量

力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台备战技术面试&#xff1f;力扣提供海量技术面试资源&#xff0c;帮助你高效提升编程技能&#xff0c;轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/number-of-equivalent-domino-pa…

主机的具体权限规划:ACL的使用

目的&#xff1a;针对某一用户或某一组来设置特定权限需求&#xff0c;针对上&#xff0c;接着设置 ACL可以针对单一用户&#xff0c;文件&#xff0c;或者目录来进行rwx的权限设置&#xff0c;对于需要特殊权限的设置非常有帮助。 第一&#xff0c;查看文件系统是否支持&…

frida - 2.hook使用

frida hook 方法 下面是frida客户端命令行的参数帮助 Frida两种操作模式 1.attach 模式 将一个脚本注入到 Android 目标进程,即需要App处于启动状态, 这意味着只能从 当前时机往后hook。 frida -U -l myhook.js com.xxx.xxxx参数解释: -U 指定对USB设备操作 -l 指定…

08 木谷博客系统RBAC权限设计

这节内容说一下木谷博客系统的权限设计,采用现在主流的权限模型RBAC,对应关系如下: 以上5张表都在mugu_auth_server这个库中 该部分的服务单独定义在user-boot这个模块中。 将角色、权限对应关系加载到Redis 木谷博客系统在认证中心颁发令牌的时候是将用户的角色保存到令牌…

LabVIEW通过编程将图形类控件的X轴显示为时间戳

LabVIEW通过编程将图形类控件的X轴显示为时间戳 每个版本的LabVIEW中都有属性节点&#xff0c;可以以编程方式调整X轴和Y轴格式。对于不同版本的LabVIEW&#xff0c;这些属性节点无法在同一个位置找到。请参阅以下部分&#xff0c;了解特定版本LabVIEW的相关属性节点的位置。 …

静态住宅IP代理实际应用:它的强大用途你知道吗?

静态住宅IP代理与动态IP代理相比&#xff0c;提供了更稳定的网络身份&#xff0c;使得企业在进行数据采集、区域定位营销和市场研究时更为高效。同时&#xff0c;它也是提高在线隐私保护和避免封禁的有效工具。 通过详细分析&#xff0c;你将能全面了解静态住宅IP代理的应用&a…

C语言题目强化-DAY12

题型指引 一、选择题二、编程题 ★★写在前面★★ 本题库源自互联网&#xff0c;仅作为个人学习使用&#xff0c;记录C语言题目练习的过程&#xff0c;如果对你也有帮助&#xff0c;那就点个赞吧。 一、选择题 1、请阅读以下程序&#xff0c;其运行结果是&#xff08; &#x…