当前位置:首页>python>Python从入门到实战-第 5 章:练习示例

Python从入门到实战-第 5 章:练习示例

  • 2026-06-30 21:37:55
Python从入门到实战-第 5 章:练习示例

第五章的结尾,我们给出了一个练习,是想实现一个工具包,包含两个模块,一个是验证模块,可以用来验证手机、邮箱是否合法。还有一个模块是读取文件中的数据,比如可以读取txt,csv文件。

下面我们就开始着手实现。我准备用Poetry来管理我们的项目。

首先,我们打开VSCode,切换到你创建的一个工作目录(也就是你在某个磁盘下存放工程的文件夹),然后打开TERMINAL终端,终端会自动在当前的工作目录下,接下来我们就可以使用Poetry的命令创建一个项目,名为tools,命令为:poetry new tools。这样就会自动产生一个tools文件夹,它的目录结构是这样的:

tools├── pyproject.toml├── README.md├── src│   └── tools│       └── __init__.py└── tests    └── __init__.py

我们在src/tools文件夹下创建两个Python文件,一个是validator.py,一个是file_reader.py。

在validator模块中我想实现以下几个功能:

  • • 验证手机号是否有效
  • • 验证邮箱格式
  • • 验证url格式。

在file_reader模块中我想实现这么几个功能:

  • • 读取txt文件
  • • 读取csv文件
  • • 读取json文件。

在validator.py中我写下了这样的代码:

import refrom urllib.parse import urlparsedef is_valid_phone_num(number: str) -> bool:    """    验证手机号    :param number: 手机号    :type number: str    :return: 有效返回True,否则返回False    :rtype: bool    """    # 使用正则表达式验证,以1开头,第二位是3-9之间的数字,后面是0-9的9个数字    pattern = re.compile(r"1[3-9]\d{9}")    return bool(re.fullmatch(pattern, number))def is_valid_email(email: str) -> bool:    """    验证邮箱格式    :param email: 邮箱地址    :type email: str    :return: 有效返回True,否则返回False    :rtype: bool    """    # 正则表达式挺复杂的,这是从网上查找的    pattern = r"^[a-zA-Z0-9_.+-]+@[a-zA-Z0-9-]+\.[a-zA-Z0-9-.]+$"    return bool(re.match(pattern, email))def is_valid_url(url: str) -> bool:    """    验证url,支持http和https    :param url: url地址    :type url: str    :return: 有效返回True,否则返回False    :rtype: bool    """    if not url or url.strip() == "":        return False    url = url.strip()    # 必须以http://或https://开头    # 下面多个相邻的字符串会被自动拼接成一个    pattern = re.compile(        r"^https?:\/\/"  # 强制http/https开头        r"(?:(?:[a-zA-Z0-9-]+\.)+[a-zA-Z]{2,}|(?:\d{1,3}\.){3}\d{1,3})"  # 域名或IP        r"(?::\d{1,5})?"  # 可选端口(1-5位数字)        r"(?:\/[^\s]*)?$",  # 可选路径/参数        re.IGNORECASE,    )    if not re.match(pattern, url):        return False    # 做一些更细节的判断    try:        parsed_url = urlparse(url)        port = parsed_url.port        # 端口号范围在0-65535        if port is not None and (port < 0 or port > 65535):            return False        # 如果是IP地址,则每个数字都应该在0-255范围        hostname = parsed_url.hostname        if hostname is None:            return False        if hostname.replace(".", "").isdigit():            ip_parts = hostname.split(".")            if len(ip_parts) != 4:                return False            for part in ip_parts:                if not part.isdigit() or int(part) < 0 or int(part) > 255:                    return False    except (ValueError, TypeError, AttributeError):        return False    return True

在file_reader.py中我是这么写的:

from pathlib import Pathimport csvimport jsondef read_txt(file_path: str, encoding: str) -> list:    """    读取txt文件    :param file_path: txt文件路径    :type file_path: str    :param encoding: 编码格式    :type encoding: str    :return: 文件每行的内容    :rtype: list    """    path = Path(file_path)    return path.read_text(encoding).splitlines()def read_csv(file_path: str, encoding: str, delimiter: str = ',') -> list:    """    读取csv文件    :param file_path: csv文件路径    :type file_path: str    :param encoding: 编码格式    :type encoding: str    :return: 文件的每行内容    :rtype: list    """    data = []    with open(file_path, "r", encoding=encoding) as f:        reader = csv.reader(f, delimiter=delimiter)        for row in reader:            if row: # 过滤掉空行                cleaned_row = [cell.strip() for cell in row]                data.append(cleaned_row)    return datadef read_json(file_path: str, encoding: str) -> dict | list:    """    读取json文件    :param file_path: json文件路径    :type file_path: str    :param encoding: 文件编码格式    :type encoding: str    :return: 返回字典或列表    :rtype: dict | list    """    with open(file_path, "r", encoding=encoding) as f:        return json.load(f)if __name__ == "__main__":    csv_path = 'H:\\py_workspace\\tools\\tests\\data\\test.csv'    data = read_csv(csv_path, 'utf-8')    print(data)

写完了上面两个模块的代码,接下来就要进行测试,看看功能是否如预期执行,所以我们需要先安装一个测试框架的库,这里使用pytest,在控制台中执行如下命令:

# 添加 pytest 作为开发依赖poetry add --group dev pytest# pytest-cov 用于生成测试覆盖率报告poetry add --group dev pytest-cov

我们可以在tests目录中创建两个测试文件,test_validator.py和test_file_reader.py。

为了能够正常使用src中的模块导入,我们需要先在项目的根目录下执行poetry install命令,这就相当于把src下的模块安装到了虚拟环境中,而且是可编辑的模式,也就是如果修改了源代码,会自动使用最新的代码。

在VSCode中我执行了poetry install命令之后,在测试文件中导入模块后,我还遇到了点小问题,就是编辑器不能代码的自动补全了,我猜测可能是因为编辑器还没识别到,实际上已经安装成功了,这一点可以通过poetry run pip list命令来验证,安装成功可以在这个列表中看到我们自己编写模块的名称,我重启了一下VSCode之后,自动补全就可以用了。

还有一点是导入模块的时候不要忘记了包名(tools),不带包名直接导入会找不到模块的。

一切正常后就可以写测试脚本了。

test_validator.py的代码如下:

from tools.validator import is_valid_phone_num, is_valid_email, is_valid_urldef test_valid_phone_num():    """    测试test_valid_phone_num    手机号都是瞎写的,如有雷同,纯属巧合    """    assert is_valid_phone_num('19811234567') is True    assert is_valid_phone_num('19912345678') is True    assert is_valid_phone_num('19912345678abc') is False    assert is_valid_phone_num('123456789') is Falsedef test_valid_email():    """    测试test_valid_email    """    assert is_valid_email('test@example.com') is True    assert is_valid_email('test.123@163.com') is True    assert is_valid_email('test@@example.qq.com') is False    assert is_valid_email('@example.com') is False    assert is_valid_email('123456') is Falsedef test_valid_url():    """    测试test_valid_url    """    assert is_valid_url('https://www.example.com') is True    assert is_valid_url('http://127.0.0.1:8080/api') is True    assert is_valid_url('https://example.com:88888') is False # 端口号超过65535    assert is_valid_url('ftp://example.com') is False # 端口号超过65535    assert is_valid_url('http://256.0.0.1') is False # ip超过255    assert is_valid_url('ftp://example.com') is False # 不是http和https

在测试file_reader模块之前我们我们需要先准备一些测试数据,我们在tests目录下创建一个data文件夹,并在里面放一些简单的数据,分别是test.txt,test.csv,test.json。具体的数据如下:

test.txt的数据内容:

Python从入门到实战工具包测试验证模块:手机号、邮箱、URL文件读取模块:TXT、CSV、JSON

test.csv的数据内容如下:

姓名,邮箱,网址未来编程实验室,futurecodinglab@126.com,没有网址张三,zhangsan@example.com,https://www.zhangsan.com李四,lisi@example.com,http://127.0.0.1:8080王五,invalid-email,ftp://invalid-url

test.json的数据如下:

{  "name": "tools",  "version": "0.1.0",  "features": ["验证", "文件读取"],  "author": {    "name": "未来编程实验室",    "email": "futurecodinglab@126.com"  }}

test_file_reader.py的代码如下:

import osfrom tools.file_reader import read_txt, read_csv,read_jsonTEST_DATA_DIR = os.path.join(os.path.dirname(__file__), "data")TXT_FILE = os.path.join(TEST_DATA_DIR, "test.txt")CSV_FILE = os.path.join(TEST_DATA_DIR, "test.csv")JSON_FILE = os.path.join(TEST_DATA_DIR, "test.json")def test_read_txt():    """    测试test_read_txt    """    lines = read_txt(TXT_FILE, 'utf-8')    assert len(lines) == 4    assert lines[0] == 'Python从入门到实战'    assert lines[2] == '验证模块:手机号、邮箱、URL'def test_read_csv():    """    测试test_read_csv    """    data = read_csv(CSV_FILE, 'utf-8')    assert data[0][0] == '姓名'    assert data[1][0] == '未来编程实验室'def test_read_json():    """    测试test_read_json    """    data = read_json(JSON_FILE, 'utf-8')    assert data['name'] == 'tools'

因为我们在这个示例中使用的是pytest测试框架,所以在编写测试脚本时要符合一些基本的规范,比如测试的py文件要以test_开头或_test结尾,测试脚本中的函数要以test_开头,用assert关键字来断言测试是否符合预期。

到目前为止,按照我们的设想代码基本上写完了,项目目前的组织结构如下:

tools├── pyproject.toml├── README.md├── src│   └── tools│       ├── validator.py│       ├── file_reader.py│       └── __init__.py└── tests│   ├── test_validator.py│   ├── test_file_reader.py    └── __init__.py

写完测试代码之后,我们就可以在控制台中执行测试脚本了,目录要切换到tools根目录,然后执行poetry run pytest即可运行全部的测试。

执行poetry run pytest --cov tools tests/命令在控制台中会打印出代码被测试的覆盖率,这有助于我们发现有多少代码被测试了,这有助于评估测试的质量。

但也需要注意的是高覆盖率并不代表着高质量,因为有可能存在假覆盖的情况,比如虽然执行了代码但没有验证结果。

在编写代码的过程中经常会出现各种问题,为了更方便的解决这些问题,我们则需要掌握一些调试技巧,断点调试可以说一种非常常用的技巧。

以本练习为例,我们在这里简单说一下在VSCode中如何进行断点调试Python项目。

首先看一下我们的tools根目录是否有一个.vscode的文件夹,项目如果有运行一般会自动创建,如果没有则创建一个,并在这个文件夹中创建一个launch.json文件,在这个配置文件中写如下配置:

{  "version": "0.2.0",  "configurations": [    {      "name": "Debug PyTest",      "type": "debugpy",      "request": "launch",      "module": "pytest",      "args": ["tests/", "-v"],      "console": "integratedTerminal",      "justMyCode":false,      "env": {        "PYTHONPATH": "${workspaceFolder}"      }    },    {      "name": "Debugger Main: Current File",      "type": "debugpy",      "request": "launch",      "program": "${file}",      "console": "integratedTerminal",      "justMyCode":false,      "env": {        "PYTHONPATH": "${workspaceFolder}"      },      "args": []    }  ]}

这个配置中第一个“Debug PyTest”是为了让我们可以在运行tests的脚本时进入断点调试模式,“Debugger Main: Current File”的配置是为了让我们可以在src中的Python文件执行断点调试,这个我们可以在VSCode中的点击左侧的Run and Debug按钮进入,然后在下拉框中可以选择调试时执行哪种类型的调试。具体如图:

validator.py和file_reader.py模块的实现都是用的基础库,写的也都是比较简单的代码,可以算是自己造轮子,在学习的过程中我认为还是有必要的。

实际开发中为了提升效率和更加完善,我们可以使用一些比较流行的第三方库,比如phonenumbers、email-validator、validators、pandas等。

你在练习时遇到了哪些问题?我们可以一起来讨论。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-03 16:35:46 HTTP/2.0 GET : https://f.mffb.com.cn/a/494342.html
  2. 运行时间 : 0.294963s [ 吞吐率:3.39req/s ] 内存消耗:4,680.76kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=d94c2c2b775d7c151ed2c31bdded9e0d
  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.000417s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000669s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000290s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.001208s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000614s ]
  6. SELECT * FROM `set` [ RunTime:0.020673s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000708s ]
  8. SELECT * FROM `article` WHERE `id` = 494342 LIMIT 1 [ RunTime:0.002096s ]
  9. UPDATE `article` SET `lasttime` = 1783067746 WHERE `id` = 494342 [ RunTime:0.010049s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.007415s ]
  11. SELECT * FROM `article` WHERE `id` < 494342 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.002799s ]
  12. SELECT * FROM `article` WHERE `id` > 494342 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.019341s ]
  13. SELECT * FROM `article` WHERE `id` < 494342 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.044957s ]
  14. SELECT * FROM `article` WHERE `id` < 494342 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.054764s ]
  15. SELECT * FROM `article` WHERE `id` < 494342 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.057283s ]
0.296648s