当前位置:首页>python>Python 零基础100天—Day28 JSON 处理

Python 零基础100天—Day28 JSON 处理

  • 2026-07-01 22:46:00
Python 零基础100天—Day28 JSON 处理

🐍JSON 处理 — 数据交换的万能语言

🕐 预计用时:2-3 小时 | 🎯 目标:掌握 JSON 读写、嵌套处理、文件交互、API 数据解析


📖 今日目录

  1. JSON 是什么?为什么重要?
  2. json.loads() — JSON 字符串 → Python 对象
  3. json.dumps() — Python 对象 → JSON 字符串
  4. json.load() / json.dump() — 文件读写
  5. 嵌套结构处理
  6. 类型映射与注意事项
  7. 美化输出与排序
  8. 实战:解析 API 数据
  9. 实战:配置文件管理器
  10. 今日小结

1. JSON 是什么?为什么重要?

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。几乎所有编程语言都支持它,是互联网数据传输的"通用语言"。

你每天都在接触 JSON:

  • 🌐 网页从服务器获取的数据 → JSON
  • 📱 手机 App 请求后端接口 → JSON
  • ⚙️ 配置文件(如 VS Code 的 settings.json)→ JSON
  • 🤖 和 AI 对话的请求/响应 → JSON
# JSON 长这样:
{
    "name": "张三",
    "age": 25,
    "is_student": false,
    "hobbies": ["编程", "游戏", "游泳"],
    "address": {
        "city": "北京",
        "zip": "100000"
    },
    "spouse": null
}

💡 JSON vs Python 字典:看起来很像,但有区别!JSON 的键必须用双引号,值只能是特定类型(字符串、数字、布尔、null、数组、对象)。

Python 与 JSON 的类型对照

JSON 类型
Python 类型
示例
object {}
dict
{"key": "value"}
array []
list
[1, 2, 3]
string ""
str
"hello"
number(整数)
int
42
number(小数)
float
3.14
true / false
True / False
True
null
None
None

2. json.loads() — JSON 字符串 → Python 对象

json.loads() 把 JSON 格式的字符串转换成 Python 对象(通常是字典)。"loads" = "load string"(加载字符串)。

import json

# 一个 JSON 格式的字符串
json_str = '{"name": "张三", "age": 25, "is_student": false}'

# 转换成 Python 字典
data = json.loads(json_str)
print(data)           # {'name': '张三', 'age': 25, 'is_student': False}
print(type(data))     # <class 'dict'>
print(data["name"])   # 张三
print(data["age"])    # 25
# JSON 数组 → Python 列表
json_str = '[1, 2, 3, "hello", true, null]'
result = json.loads(json_str)
print(result)         # [1, 2, 3, 'hello', True, None]
print(type(result))   # <class 'list'>
# 嵌套的 JSON
json_str = '''
{
    "students": [
        {"name": "张三", "score": 95},
        {"name": "李四", "score": 88}
    ],
    "class": "三年二班"
}
'''
data = json.loads(json_str)
print(data["class"])                      # 三年二班
print(data["students"][0]["name"])        # 张三
print(data["students"][1]["score"])       # 88

⚠️ 常见错误:JSON 字符串必须用双引号!单引号会报错。
json.loads("{'name': '张三'}") → ❌ JSONDecodeError
json.loads('{"name": "张三"}') → ✅ 正确

处理 JSON 解析错误

import json

bad_json = '{"name": "张三", age: 25}'  # age 没有双引号

try:
    data = json.loads(bad_json)
except json.JSONDecodeError as e:
    print(f"JSON 解析失败: {e}")
    # JSON 解析失败: Expecting property name enclosed in double quotes: line 1 column 22 (char 21)

3. json.dumps() — Python 对象 → JSON 字符串

json.dumps() 把 Python 对象转换成 JSON 格式的字符串。"dumps" = "dump string"(转储字符串)。

import json

# Python 字典 → JSON 字符串
data = {
    "name": "张三",
    "age": 25,
    "is_student": False,
    "hobbies": ["编程", "游戏"],
    "address": None
}

json_str = json.dumps(data)
print(json_str)
# {"name": "\u5f20\u4e09", "age": 25, "is_student": false, "hobbies": ["\u7f16\u7a0b", "\u6e38\u620f"], "address": null}

print(type(json_str))  # <class 'str'>

⚠️ 中文被转义了?默认情况下,dumps 会把非 ASCII 字符转义成 \uXXXX。加上 ensure_ascii=False 就能保留中文。

# 保留中文
json_str = json.dumps(data, ensure_ascii=False)
print(json_str)
# {"name": "张三", "age": 25, "is_student": false, "hobbies": ["编程", "游戏"], "address": null}

类型转换对照

Python 类型
→ JSON 类型
示例
dict
object
{"key": "value"}
list / tuple
array
[1, 2, 3]
str
string
"hello"
int / float
number
42 / 3.14
True / False
true / false
true
None
null
null
⚠️ set
❌ 报错!
需先转 list
⚠️ datetime
❌ 报错!
需先转字符串
import json

# ❌ set 不能直接转 JSON
data = {"tags": {"python", "java", "go"}}
# json.dumps(data)  # TypeError: Object of type set is not JSON serializable

# ✅ 先转成 list
data["tags"] = list(data["tags"])
print(json.dumps(data))  # {"tags": ["python", "go", "java"]}

4. json.load() / json.dump() — 文件读写

load() 和 dump()(没有 s)直接操作文件对象,省去手动读写的步骤。

写入 JSON 文件

import json

data = {
    "name": "小龙",
    "version": "1.0",
    "skills": ["Python", "正则", "JSON"],
    "config": {
        "theme": "dark",
        "language": "zh-CN"
    }
}

# 写入文件
with open("config.json", "w", encoding="utf-8") as f:
    json.dump(data, f, ensure_ascii=False, indent=2)

print("写入完成!")
# config.json 文件内容:
{
  "name": "小龙",
  "version": "1.0",
  "skills": [
    "Python",
    "正则",
    "JSON"
  ],
  "config": {
    "theme": "dark",
    "language": "zh-CN"
  }
}

读取 JSON 文件

import json

# 从文件读取
with open("config.json", "r", encoding="utf-8") as f:
    data = json.load(f)

print(data["name"])             # 小龙
print(data["config"]["theme"])  # dark
print(data["skills"][0])        # Python

💡 load vs loads 的区别:
json.load(f) → 从文件对象读取
json.loads(string) → 从字符串解析
json.dump(data, f) → 写入文件对象
json.dumps(data) → 转成字符串


5. 嵌套结构处理

真实世界的 JSON 往往层层嵌套——学会"钻"进去取数据是核心技能。

import json

# 模拟一个 API 返回的复杂数据
api_response = {
    "status": "success",
    "data": {
        "users": [
            {
                "id": 1,
                "name": "张三",
                "contacts": {
                    "email": "zhangsan@example.com",
                    "phone": "13800138001"
                },
                "orders": [
                    {"order_id": "A001", "amount": 99.9},
                    {"order_id": "A002", "amount": 199.0}
                ]
            },
            {
                "id": 2,
                "name": "李四",
                "contacts": {
                    "email": "lisi@example.com",
                    "phone": "13800138002"
                },
                "orders": [
                    {"order_id": "B001", "amount": 59.5}
                ]
            }
        ],
        "total": 2
    }
}

# 取出张三的邮箱
email = api_response["data"]["users"][0]["contacts"]["email"]
print(email)  # zhangsan@example.com

# 取出李四的第一个订单金额
amount = api_response["data"]["users"][1]["orders"][0]["amount"]
print(amount)  # 59.5

安全取值:防止 KeyError

# ❌ 直接取值,key 不存在会报错
# value = api_response["data"]["users"][99]  # IndexError!

# ✅ 方法1:先判断
if "data" in api_response and "users" in api_response["data"]:
    users = api_response["data"]["users"]
    print(f"共有 {len(users)} 个用户")

# ✅ 方法2:用 get() 设置默认值
config = json.loads('{"theme": "dark"}')
font_size = config.get("font_size", 16)  # 不存在就用默认值 16
print(font_size)  # 16

遍历嵌套数据

import json

# 遍历所有用户和订单
for user in api_response["data"]["users"]:
    name = user["name"]
    email = user["contacts"]["email"]
    print(f"\n👤 {name} ({email})")

    for order in user["orders"]:
        oid = order["order_id"]
        amount = order["amount"]
        print(f"   📦 订单 {oid}: ¥{amount}")

# 输出:
# 👤 张三 (zhangsan@example.com)
#    📦 订单 A001: ¥99.9
#    📦 订单 A002: ¥199.0
#
# 👤 李四 (lisi@example.com)
#    📦 订单 B001: ¥59.5

6. 类型映射与注意事项

JSON 和 Python 的类型不是完全一一对应的,有几个容易踩的坑。

坑 1:整数键 → 字符串键

import json

# Python 字典用整数做键
data = {1: "一", 2: "二", 3: "三"}
json_str = json.dumps(data)
print(json_str)  # {"1": "一", "2": "二", "3": "三"}

# 从 JSON 变回来,键变成字符串了!
result = json.loads(json_str)
print(result)       # {'1': '一', '2': '二', '3': '三'}
print(result[1])    # ❌ KeyError: 1
print(result["1"])  # ✅ 一

坑 2:元组 → 数组 → 列表

import json

# Python 元组
data = {"point": (10, 20)}
json_str = json.dumps(data)
print(json_str)  # {"point": [10, 20]}

# 读回来变成列表了
result = json.loads(json_str)
print(type(result["point"]))  # <class 'list'>  不再是 tuple!

坑 3:None → null → None

import json

data = {"value": None}
json_str = json.dumps(data)
print(json_str)  # {"value": null}

result = json.loads(json_str)
print(result["value"])     # None
print(result["value"] is None)  # True ✅

坑 4:布尔值的大小写

import json

# JSON: true/false(小写)
# Python: True/False(大写)

data = {"flag": True}
json_str = json.dumps(data)
print(json_str)  # {"flag": true}  ← JSON 格式是小写

result = json.loads(json_str)
print(result["flag"])  # True  ← Python 又变回大写

⚠️ 总结:JSON 不是 Python!
从 JSON 读回来的数据,整数键变字符串、元组变列表、大小写可能变。如果你对类型敏感,读取后要手动转换。


7. 美化输出与排序

调试时,一行 JSON 根本没法看。dumps 的参数可以帮你格式化。

import json

data = {
    "name": "张三",
    "age": 25,
    "city": "北京",
    "skills": ["Python", "Java", "Go"]
}

# 默认输出:一行,挤在一起
print(json.dumps(data, ensure_ascii=False))
# {"name": "张三", "age": 25, "city": "北京", "skills": ["Python", "Java", "Go"]}

# indent=2:缩进美化
print(json.dumps(data, ensure_ascii=False, indent=2))
# {
#   "name": "张三",
#   "age": 25,
#   "city": "北京",
#   "skills": [
#     "Python",
#     "Java",
#     "Go"
#   ]
# }

# sort_keys=True:按键名排序
print(json.dumps(data, ensure_ascii=False, indent=2, sort_keys=True))
# {
#   "age": 25,
#   "city": "北京",
#   "name": "张三",
#   "skills": [
#     "Python",
#     "Java",
#     "Go"
#   ]
# }

分隔符控制

import json

data = {"name": "张三", "age": 25}

# 默认分隔符
print(json.dumps(data, ensure_ascii=False))
# {"name": "张三", "age": 25}

# 自定义分隔符:紧凑模式
print(json.dumps(data, ensure_ascii=False, separators=(",", ":")))
# {"name":"张三","age":25}

# 自定义分隔符:特殊格式
print(json.dumps(data, ensure_ascii=False, separators=(", ", " = ")))
# {"name" = "张三", "age" = 25}

8. 实战:解析 API 数据

这是 JSON 最常见的用途——从网络 API 获取数据并解析。我们模拟一个真实的天气 API 响应。

import json

# 模拟 API 返回的 JSON 数据(实际中用 requests.get() 获取)
api_json = '''
{
    "city": "北京",
    "update_time": "2024-01-15 10:30:00",
    "forecast": [
        {
            "date": "2024-01-15",
            "weather": "晴",
            "temp_high": 5,
            "temp_low": -3,
            "wind": "北风 3级"
        },
        {
            "date": "2024-01-16",
            "weather": "多云",
            "temp_high": 3,
            "temp_low": -5,
            "wind": "西北风 4级"
        },
        {
            "date": "2024-01-17",
            "weather": "小雪",
            "temp_high": 0,
            "temp_low": -8,
            "wind": "北风 5级"
        }
    ]
}
'''

# 解析 JSON
weather = json.loads(api_json)

# 提取信息
print(f"🏙️ 城市: {weather['city']}")
print(f"🕐 更新: {weather['update_time']}")
print()

for day in weather["forecast"]:
    date = day["date"]
    desc = day["weather"]
    high = day["temp_high"]
    low = day["temp_low"]
    wind = day["wind"]

    # 根据天气选 emoji
    emoji = {"晴": "☀️", "多云": "⛅", "小雪": "🌨️"}.get(desc, "🌤️")

    print(f"{emoji} {date}: {desc}")
    print(f"   🌡️ {low}°C ~ {high}°C  💨 {wind}")
    print()

# 输出:
# 🏙️ 城市: 北京
# 🕐 更新: 2024-01-15 10:30:00
#
# ☀️ 2024-01-15: 晴
#    🌡️ -3°C ~ 5°C  💨 北风 3级
#
# ⛅ 2024-01-16: 多云
#    🌡️ -5°C ~ 3°C  💨 西北风 4级
#
# 🌨️ 2024-01-17: 小雪
#    🌡️ -8°C ~ 0°C  💨 北风 5级

配合 requests 请求真实 API

import json
import requests

# 请求一个免费的测试 API
response = requests.get("https://httpbin.org/json")
data = response.json()  # 等价于 json.loads(response.text)

print(json.dumps(data, indent=2, ensure_ascii=False))
# {
#   "slideshow": {
#     "author": "Yours Truly",
#     "date": "date of publication",
#     "slides": [
#       {
#         "title": "Wake up to WonderWidgets!",
#         "type": "all"
#       },
#       ...
#     ],
#     "title": "Sample Slide Show"
#   }
# }

# .json() 是 requests 库的便捷方法
# 等价于:data = json.loads(response.text)

💡 requests 的 .json() 方法:
response.json() 内部就是调用 json.loads(response.text),是快捷方式。


9. 实战:配置文件管理器

JSON 非常适合做配置文件——结构清晰、可读性强、语言无关。来写一个完整的配置管理工具。

import json
import os

CONFIG_FILE = "app_config.json"

# 默认配置
DEFAULT_CONFIG = {
    "app_name": "我的应用",
    "version": "1.0.0",
    "debug": False,
    "database": {
        "host": "localhost",
        "port": 3306,
        "name": "mydb"
    },
    "logging": {
        "level": "INFO",
        "file": "app.log"
    },
    "allowed_ips": ["127.0.0.1", "192.168.1.0/24"]
}


def load_config():
    """加载配置,不存在则创建默认配置"""
    if not os.path.exists(CONFIG_FILE):
        save_config(DEFAULT_CONFIG)
        print("📝 已创建默认配置文件")
        return DEFAULT_CONFIG

    with open(CONFIG_FILE, "r", encoding="utf-8") as f:
        return json.load(f)


def save_config(config):
    """保存配置到文件"""
    with open(CONFIG_FILE, "w", encoding="utf-8") as f:
        json.dump(config, f, ensure_ascii=False, indent=2)


def get_value(config, key_path, default=None):
    """用点号路径获取值,如 'database.host'"""
    keys = key_path.split(".")
    current = config

    for key in keys:
        if isinstance(current, dict) and key in current:
            current = current[key]
        else:
            return default

    return current


def set_value(config, key_path, value):
    """用点号路径设置值"""
    keys = key_path.split(".")
    current = config

    for key in keys[:-1]:
        if key not in current:
            current[key] = {}
        current = current[key]

    current[keys[-1]] = value
    save_config(config)


# ---- 使用示例 ----
config = load_config()

# 读取配置
print(get_value(config, "app_name"))          # 我的应用
print(get_value(config, "database.host"))     # localhost
print(get_value(config, "database.port"))     # 3306
print(get_value(config, "logging.level"))     # INFO
print(get_value(config, "not.exist", "无"))   # 无

# 修改配置
set_value(config, "database.port", 5432)
set_value(config, "debug", True)
set_value(config, "logging.level", "DEBUG")

# 验证修改
print(get_value(config, "database.port"))  # 5432
print(get_value(config, "debug"))          # True

💡 点号路径取值get_value(config, "database.host"))是配置管理的常见模式,比一层层 config["database"]["host"] 更优雅,还能处理 key 不存在的情况。


10. 今日小结

函数
用途
记忆口诀
json.loads(s)
字符串 → Python
load string
json.dumps(obj)
Python → 字符串
dump string
json.load(f)
文件 → Python
load file
json.dump(obj, f)
Python → 文件
dump file

核心要点

  • ✅ JSON 是数据交换的"通用语言",几乎所有语言都支持
  • ✅ loads/dumps 操作字符串,load/dump 操作文件
  • ✅ 中文输出要加 ensure_ascii=False
  • ✅ 美化输出用 indent=2
  • ✅ JSON 的键必须是字符串,值不能有 set/datetime 等特殊类型
  • ✅ 从 JSON 读回来:整数键变字符串、元组变列表
  • ✅ 嵌套取值用 .get() 防止 KeyError
  • ✅ 配置文件管理是 JSON 最实用的场景之一

常用参数速查

# 常用 dumps 参数
json.dumps(data,
    ensure_ascii=False,   # 保留中文
    indent=2,             # 缩进美化
    sort_keys=True,       # 键排序
    separators=(",", ":") # 紧凑分隔
)

# 读取时处理异常
try:
    data = json.loads(text)
except json.JSONDecodeError as e:
    print(f"JSON 格式错误: {e}")

🎯 练习建议:
1. 创建一个 JSON 格式的"个人名片"文件,写入姓名、年龄、技能列表,再读取出来
2. 模拟一个电商 API 响应(商品列表 + 价格),用代码计算总价
3. 写一个函数,支持用 "a.b.c" 格式的路径修改嵌套字典的值


📚 Day28 完成!明天学习 CSV 处理 —— 表格数据的读写利器

轻松时刻:

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-03 15:04:23 HTTP/2.0 GET : https://f.mffb.com.cn/a/498013.html
  2. 运行时间 : 0.143217s [ 吞吐率:6.98req/s ] 内存消耗:4,767.92kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=b09d9c560ec7fc3a4306b46b8963f455
  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.000527s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000742s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000277s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000246s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000541s ]
  6. SELECT * FROM `set` [ RunTime:0.000226s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000734s ]
  8. SELECT * FROM `article` WHERE `id` = 498013 LIMIT 1 [ RunTime:0.000922s ]
  9. UPDATE `article` SET `lasttime` = 1783062263 WHERE `id` = 498013 [ RunTime:0.009442s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000400s ]
  11. SELECT * FROM `article` WHERE `id` < 498013 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000577s ]
  12. SELECT * FROM `article` WHERE `id` > 498013 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000414s ]
  13. SELECT * FROM `article` WHERE `id` < 498013 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.000693s ]
  14. SELECT * FROM `article` WHERE `id` < 498013 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.021915s ]
  15. SELECT * FROM `article` WHERE `id` < 498013 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.035651s ]
0.144858s