当前位置:首页>python>Python unittest框架——官方单元测试框架

Python unittest框架——官方单元测试框架

  • 2026-06-29 15:03:57
Python unittest框架——官方单元测试框架

一、unittest概述

unittest 是 Python 标准库自带的单元测试框架,灵感来源于 Java 的 JUnit。它提供了测试用例组织、测试固件、断言方法、测试运行器等完整功能,是 Python 官方推荐的测试工具。

import unittest

classTestMath(unittest.TestCase):
deftest_add(self):
self.assertEqual(2 + 35)

deftest_subtract(self):
self.assertEqual(5 - 32)

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

二、unittest核心组件

组件
说明
TestCase
测试用例基类,所有测试类继承它
TestSuite
测试套件,组织多个测试用例
TestRunner
测试运行器,执行测试并输出结果
TestLoader
测试加载器,自动发现和加载测试
TestFixture
测试固件,测试前后的准备和清理

三、基本用法

3.1 创建测试用例

import unittest

classTestStringMethods(unittest.TestCase):

deftest_upper(self):
self.assertEqual('hello'.upper(), 'HELLO')

deftest_isupper(self):
self.assertTrue('HELLO'.isupper())
self.assertFalse('Hello'.isupper())

deftest_split(self):
        s = 'hello world'
self.assertEqual(s.split(), ['hello''world'])
withself.assertRaises(TypeError):
            s.split(2)

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

3.2 运行测试

# 运行单个文件
python test_math.py

# 详细输出(-v)
python test_math.py -v

# 运行指定测试类
python test_math.py TestMath

# 运行指定测试方法
python test_math.py TestMath.test_add

四、断言方法

4.1 常用断言

断言方法
说明
assertEqual(a, b)
a == b
assertNotEqual(a, b)
a != b
assertTrue(x)
x 为 True
assertFalse(x)
x 为 False
assertIs(a, b)
a is b
assertIsNot(a, b)
a is not b
assertIsNone(x)
x is None
assertIsNotNone(x)
x is not None
assertIn(a, b)
a in b
assertNotIn(a, b)
a not in b
assertIsInstance(a, b)
isinstance(a, b)
assertNotIsInstance(a, b)
not isinstance(a, b)

4.2 数值比较断言

断言方法
说明
assertAlmostEqual(a, b)
round(a-b, 7) == 0
assertNotAlmostEqual(a, b)
round(a-b, 7) != 0
assertGreater(a, b)
a > b
assertGreaterEqual(a, b)
a >= b
assertLess(a, b)
a < b
assertLessEqual(a, b)
a <= b

4.3 异常断言

import unittest

defdivide(a, b):
if b == 0:
raise ValueError("除数不能为零")
return a / b

classTestDivide(unittest.TestCase):
deftest_divide_by_zero(self):
# 方式1:使用 assertRaises 上下文管理器
withself.assertRaises(ValueError):
            divide(100)

# 方式2:捕获异常对象
withself.assertRaises(ValueError) as cm:
            divide(100)
self.assertEqual(str(cm.exception), "除数不能为零")

deftest_divide_normal(self):
        result = divide(102)
self.assertEqual(result, 5)

4.4 集合断言

classTestCollections(unittest.TestCase):
deftest_list_equality(self):
self.assertListEqual([123], [123])

deftest_tuple_equality(self):
self.assertTupleEqual((12), (12))

deftest_dict_equality(self):
self.assertDictEqual({'a'1'b'2}, {'b'2'a'1})

deftest_set_equality(self):
self.assertSetEqual({123}, {321})

4.5 自定义错误消息

deftest_with_message(self):
    value = 10
self.assertEqual(value, 5f"预期是5,实际是{value}")

五、测试固件(Fixtures)

5.1 方法级别

import unittest

classTestDatabase(unittest.TestCase):
defsetUp(self):
"""每个测试方法执行前运行"""
print("准备测试数据")
self.data = [123]

deftearDown(self):
"""每个测试方法执行后运行"""
print("清理测试数据")
self.data = None

deftest_something(self):
self.assertEqual(len(self.data), 3)

5.2 类级别

classTestDatabase(unittest.TestCase):
    @classmethod
defsetUpClass(cls):
"""整个测试类执行前运行一次"""
print("连接数据库")
        cls.connection = "database_connection"

    @classmethod
deftearDownClass(cls):
"""整个测试类执行后运行一次"""
print("关闭数据库连接")
        cls.connection = None

deftest_query(self):
self.assertIsNotNone(self.connection)

5.3 模块级别

import unittest

defsetUpModule():
"""模块内所有测试执行前运行"""
print("模块初始化")

deftearDownModule():
"""模块内所有测试执行后运行"""
print("模块清理")

classTestModule1(unittest.TestCase):
deftest_a(self):
self.assertTrue(True)

六、测试套件

6.1 手动构建套件

import unittest
from test_math import TestMath
from test_string import TestString

defsuite():
    suite = unittest.TestSuite()
    suite.addTest(TestMath('test_add'))
    suite.addTest(TestMath('test_subtract'))
    suite.addTest(TestString('test_upper'))
return suite

if __name__ == '__main__':
    runner = unittest.TextTestRunner()
    runner.run(suite())

6.2 自动发现测试

# 自动发现当前目录下所有 test_*.py 文件
suite = unittest.defaultTestLoader.discover('tests', pattern='test_*.py')
unittest.TextTestRunner().run(suite)

七、跳过测试

import unittest
import sys

classTestSkip(unittest.TestCase):

deftest_not_implemented(self):
self.skipTest("功能未实现")

    @unittest.skip("跳过此测试")
deftest_skip_demo(self):
self.assertTrue(False)

    @unittest.skipIf(sys.version_info < (38), "需要 Python 3.8+")
deftest_python_version(self):
self.assertTrue(True)

    @unittest.skipUnless(sys.platform.startswith("linux"), "仅 Linux 平台")
deftest_linux_only(self):
self.assertTrue(True)

    @unittest.expectedFailure
deftest_expected_failure(self):
self.assertEqual(12)  # 预计会失败,不计入失败数

八、实战案例

8.1 测试计算器类

import unittest

classCalculator:
defadd(self, a, b):
return a + b

defsubtract(self, a, b):
return a - b

defmultiply(self, a, b):
return a * b

defdivide(self, a, b):
if b == 0:
raise ValueError("除数不能为零")
return a / b

classTestCalculator(unittest.TestCase):

    @classmethod
defsetUpClass(cls):
print("初始化计算器测试")
        cls.calc = Calculator()

    @classmethod
deftearDownClass(cls):
print("计算器测试完成")
        cls.calc = None

defsetUp(self):
print("  执行测试前准备")

deftearDown(self):
print("  执行测试后清理")

deftest_add_positive(self):
self.assertEqual(self.calc.add(23), 5)

deftest_add_negative(self):
self.assertEqual(self.calc.add(-1, -2), -3)

deftest_add_zero(self):
self.assertEqual(self.calc.add(50), 5)

deftest_subtract(self):
self.assertEqual(self.calc.subtract(103), 7)
self.assertEqual(self.calc.subtract(58), -3)

deftest_multiply(self):
self.assertEqual(self.calc.multiply(45), 20)
self.assertEqual(self.calc.multiply(-32), -6)

deftest_divide_normal(self):
self.assertEqual(self.calc.divide(102), 5)
self.assertAlmostEqual(self.calc.divide(103), 3.3333333333333335)

deftest_divide_by_zero(self):
withself.assertRaises(ValueError):
self.calc.divide(100)

deftest_add_floats(self):
        result = self.calc.add(0.10.2)
self.assertAlmostEqual(result, 0.3, places=7)

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

8.2 测试用户管理系统

import unittest

classUser:
def__init__(self, username, email):
self.username = username
self.email = email
self.is_active = True

defdeactivate(self):
self.is_active = False

classUserManager:
def__init__(self):
self.users = []

defadd_user(self, username, email):
ifself.find_user_by_username(username):
raise ValueError(f"用户名 {username} 已存在")
        user = User(username, email)
self.users.append(user)
return user

deffind_user_by_username(self, username):
for user inself.users:
if user.username == username:
return user
returnNone

defget_active_users(self):
return [u for u inself.users if u.is_active]

defdeactivate_user(self, username):
        user = self.find_user_by_username(username)
if user:
            user.deactivate()
returnTrue
returnFalse

classTestUserManager(unittest.TestCase):

defsetUp(self):
"""每个测试前创建新的 UserManager"""
self.manager = UserManager()

deftearDown(self):
"""每个测试后清理"""
self.manager = None

deftest_add_user_success(self):
        user = self.manager.add_user("john""john@example.com")
self.assertIsNotNone(user)
self.assertEqual(user.username, "john")
self.assertEqual(user.email, "john@example.com")
self.assertEqual(len(self.manager.users), 1)

deftest_add_user_duplicate(self):
self.manager.add_user("john""john@example.com")
withself.assertRaises(ValueError) as cm:
self.manager.add_user("john""john2@example.com")
self.assertIn("已存在"str(cm.exception))

deftest_find_user_existing(self):
self.manager.add_user("jane""jane@example.com")
        user = self.manager.find_user_by_username("jane")
self.assertIsNotNone(user)
self.assertEqual(user.username, "jane")

deftest_find_user_not_existing(self):
        user = self.manager.find_user_by_username("nonexistent")
self.assertIsNone(user)

deftest_deactivate_user(self):
self.manager.add_user("tom""tom@example.com")
        result = self.manager.deactivate_user("tom")
self.assertTrue(result)

        user = self.manager.find_user_by_username("tom")
self.assertFalse(user.is_active)

deftest_deactivate_user_not_existing(self):
        result = self.manager.deactivate_user("nonexistent")
self.assertFalse(result)

deftest_get_active_users(self):
self.manager.add_user("u1""u1@test.com")
self.manager.add_user("u2""u2@test.com")
self.manager.deactivate_user("u2")

        active = self.manager.get_active_users()
self.assertEqual(len(active), 1)
self.assertEqual(active[0].username, "u1")

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

九、unittest vs pytest

特性
unittest
pytest
内置
需安装
测试类
必须继承 TestCase
可选
断言
self.assertEqual()assert
固件
setUp
/tearDown
fixture
参数化
需额外库
内置 @pytest.mark.parametrize
插件生态
有限
丰富
学习曲线
平缓
中等

十、最佳实践

  1. 1. 命名规范:测试文件以 test_ 开头,测试方法以 test_ 开头。
  2. 2. 测试独立性:每个测试应该独立,不依赖其他测试。
  3. 3. 使用 setUp/tearDown:减少重复代码,确保测试环境一致。
  4. 4. 一个测试一个断言:单个测试只验证一个行为。
  5. 5. 测试名称清晰:名称应描述被测试的功能。
  6. 6. 测试边界条件:包括正常值、边界值、异常值。
  7. 7. 持续运行测试:集成到 CI/CD 流程中。

十一、总结

核心要点

  • • unittest 是 Python 标准库单元测试框架,无需额外安装。
  • • 测试类继承 unittest.TestCase,测试方法以 test_ 开头。
  • • 提供丰富的断言方法(assertEqualassertTrueassertRaises 等)。
  • • 支持测试固件(setUptearDownsetUpClasstearDownClass)。
  • • 支持测试套件(TestSuite)和自动发现(TestLoader.discover)。
  • • 支持跳过测试(skipskipIfskipUnless)。

运行命令

python -m unittest test_module.py
python -m unittest discover -s tests -p "test_*.py"

掌握 unittest 是 Python 开发者的必备技能,它为代码质量提供了有力保障。对于更复杂的测试需求,可以考虑 pytest 等第三方框架。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-03 08:28:55 HTTP/2.0 GET : https://f.mffb.com.cn/a/491661.html
  2. 运行时间 : 0.088082s [ 吞吐率:11.35req/s ] 内存消耗:5,056.95kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=ce26563a0a499a3e5d15193325260697
  1. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/public/index.php ( 0.79 KB )
  2. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/autoload.php ( 0.17 KB )
  3. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_real.php ( 2.49 KB )
  4. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/platform_check.php ( 0.90 KB )
  5. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/ClassLoader.php ( 14.03 KB )
  6. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_static.php ( 4.90 KB )
  7. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  10. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  11. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  12. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  13. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  14. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  15. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  16. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  17. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-dumper/src/helper.php ( 0.18 KB )
  18. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/VarDumper.php ( 4.30 KB )
  19. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  20. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  21. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  22. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/provider.php ( 0.19 KB )
  23. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  24. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  25. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  26. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/common.php ( 0.03 KB )
  27. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  28. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  29. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/app.php ( 0.95 KB )
  30. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cache.php ( 0.78 KB )
  31. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/console.php ( 0.23 KB )
  32. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cookie.php ( 0.56 KB )
  33. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/database.php ( 2.48 KB )
  34. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  35. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/filesystem.php ( 0.61 KB )
  36. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/lang.php ( 0.91 KB )
  37. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/log.php ( 1.35 KB )
  38. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/middleware.php ( 0.19 KB )
  39. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/route.php ( 1.89 KB )
  40. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/session.php ( 0.57 KB )
  41. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/trace.php ( 0.34 KB )
  42. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/view.php ( 0.82 KB )
  43. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/event.php ( 0.25 KB )
  44. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  45. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/service.php ( 0.13 KB )
  46. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/AppService.php ( 0.26 KB )
  47. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  48. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  49. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  50. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  51. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  52. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/services.php ( 0.14 KB )
  53. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  54. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  55. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  56. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  57. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  58. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  59. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  60. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  61. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  62. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  63. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.21 KB )
  64. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.44 KB )
  65. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  66. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  67. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.29 KB )
  68. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  69. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  70. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  71. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  72. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  73. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  74. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  75. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  76. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  77. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  78. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  79. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Arr.php ( 16.63 KB )
  80. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/driver/File.php ( 7.84 KB )
  81. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  82. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  83. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/Request.php ( 0.09 KB )
  84. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  85. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/middleware.php ( 0.25 KB )
  86. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  87. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  88. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/middleware/SessionInit.php ( 1.94 KB )
  89. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Session.php ( 1.80 KB )
  90. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/driver/File.php ( 6.27 KB )
  91. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php ( 0.87 KB )
  92. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/Store.php ( 7.12 KB )
  93. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  94. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  95. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  96. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  97. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  98. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  99. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/route/app.php ( 1.72 KB )
  100. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  101. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  102. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  103. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/controller/Index.php ( 4.81 KB )
  104. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/BaseController.php ( 2.05 KB )
  105. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  106. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.44 KB )
  107. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/PDOConnection.php ( 52.47 KB )
  108. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  109. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  110. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  111. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Builder.php ( 24.06 KB )
  112. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  113. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Query.php ( 15.71 KB )
  114. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  115. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  116. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  117. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  118. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  119. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  120. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  121. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  122. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  123. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  124. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  125. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  126. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  127. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  128. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  129. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/View.php ( 1.70 KB )
  130. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  131. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  132. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  133. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  134. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-view/src/Think.php ( 8.38 KB )
  135. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  136. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/Template.php ( 46.61 KB )
  137. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/driver/File.php ( 2.41 KB )
  138. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/contract/DriverInterface.php ( 0.86 KB )
  139. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/runtime/temp/067d451b9a0c665040f3f1bdd3293d68.php ( 11.98 KB )
  140. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000649s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000773s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000290s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000290s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000470s ]
  6. SELECT * FROM `set` [ RunTime:0.000196s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000626s ]
  8. SELECT * FROM `article` WHERE `id` = 491661 LIMIT 1 [ RunTime:0.000478s ]
  9. UPDATE `article` SET `lasttime` = 1783038535 WHERE `id` = 491661 [ RunTime:0.008047s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000321s ]
  11. SELECT * FROM `article` WHERE `id` < 491661 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000639s ]
  12. SELECT * FROM `article` WHERE `id` > 491661 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000515s ]
  13. SELECT * FROM `article` WHERE `id` < 491661 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.001363s ]
  14. SELECT * FROM `article` WHERE `id` < 491661 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.001154s ]
  15. SELECT * FROM `article` WHERE `id` < 491661 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.000760s ]
0.089646s