当前位置:首页>python>Python 条件判断与循环专项练习:6 道编程题从入门到精通

Python 条件判断与循环专项练习:6 道编程题从入门到精通

  • 2026-07-02 20:49:31
Python 条件判断与循环专项练习:6 道编程题从入门到精通

配套专栏:Python 全栈修炼之路 第 06 篇《条件判断与循环控制》

难度分布:⭐ → ⭐⭐ → ⭐⭐ → ⭐⭐⭐ → ⭐⭐⭐ → ⭐⭐⭐⭐

核心覆盖:if/elif/else、for/while、break/continue、推导式、range 惰性求值、枚举、zip、矩阵操作


题目一:成绩等级判断器 ⭐

📌 题目描述

编写函数 get_grade(score),根据输入的百分制成绩返回对应的等级:

分数范围
等级
90-100
A
80-89
B
70-79
C
60-69
D
0-59
F
其他
无效分数
输入:85输出:"B"输入:105输出:"无效分数"

💡 编程思路

这道题考察 if/elif/else 的多分支判断

  • 方法一(传统 if-elif)
    :从上到下依次判断,第一个满足的条件会被执行。注意条件的顺序,应该从高到低或从低到高,避免逻辑漏洞。
  • 方法二(条件表达式嵌套)
    :使用三元运算符的嵌套形式,适合简单场景但可读性稍差。

关键点:边界值测试(60, 70, 80, 90, 100)和无效输入处理(负数、超过100)。

🖥️ 参考代码

def get_grade_if(score):    """方法一:传统 if-elif-else"""    if not isinstance(score, (intfloat)):        return "无效分数"    if score < 0 or score > 100:        return "无效分数"    elif score >= 90:        return "A"    elif score >= 80:        return "B"    elif score >= 70:        return "C"    elif score >= 60:        return "D"    else:        return "F"def get_grade_ternary(score):    """方法二:嵌套条件表达式(不推荐复杂场景使用)"""    if not isinstance(score, (intfloat)) or score < 0 or score > 100:        return "无效分数"    return "A" if score >= 90 else "B" if score >= 80 else "C" if score >= 70 else "D" if score >= 60 else "F"# 测试if __name__ == "__main__":    test_cases = [        (95"A"), (85"B"), (75"C"), (65"D"), (55"F"),        (90"A"), (80"B"), (70"C"), (60"D"), (0"F"),        (100"A"), (-5"无效分数"), (105"无效分数"), ("abc""无效分数")    ]    for score, expected in test_cases:        result = get_grade_if(score)        assert result == expected, f"分数 {score} 期望 {expected},实际 {result}"        print(f"  {score:>6} 分 → 等级 {result}")    print("\n所有测试通过 ✓")

🔗 关联知识点

知识点
说明
if/elif/else
多分支条件判断
isinstance()
类型检查
条件表达式
A if cond else B
 三元运算符
边界测试
临界值(60, 70, 80, 90)和无效值

题目二:素数筛选(埃拉托斯特尼筛法) ⭐⭐

📌 题目描述

编写函数 sieve_of_eratosthenes(n),使用埃拉托斯特尼筛法找出 2 到 n 之间的所有素数。

输入:30输出:[2, 3, 5, 7, 11, 13, 17, 19, 23, 29]

算法原理:从 2 开始,将每个素数的倍数标记为合数,剩下的就是素数。

💡 编程思路

这道题考察 嵌套循环 + 标记数组

  1. 创建一个布尔数组 is_prime[0..n],初始全部设为 True
  2. 从 2 开始遍历,如果 is_prime[i] 为 True,则 i 是素数。
  3. 将 i 的所有倍数(从 i*i 开始)标记为 False
  4. 最后收集所有 True 的索引即为素数。

优化点

  • 只需遍历到 sqrt(n),因为大于 sqrt(n) 的倍数已经被更小的素数标记过了。
  • 标记倍数时从 i*i 开始,因为 i*2, i*3, ... 已经被更小的素数处理过了。

🖥️ 参考代码

def sieve_of_eratosthenes(n):    """    埃拉托斯特尼筛法 —— O(n log log n)    核心思想:素数的倍数一定是合数    """    if n < 2:        return []    # 初始化:假设所有数都是素数    is_prime = [True] * (n + 1)    is_prime[0] = is_prime[1] = False    # 只需遍历到 sqrt(n)    for i in range(2int(n ** 0.5) + 1):        if is_prime[i]:            # 标记 i 的所有倍数为合数(从 i*i 开始优化)            for j in range(i * i, n + 1, i):                is_prime[j] = False    # 收集所有素数    return [i for i in range(2, n + 1if is_prime[i]]def sieve_optimized(n):    """优化版本:只处理奇数,节省一半空间"""    if n < 2:        return []    if n == 2:        return [2]    # 只存储奇数(3, 5, 7, ...)    sieve = [True] * ((n - 1) // 2)    for i in range((int(n ** 0.5) + 1) // 2):        if sieve[i]:            # 当前素数:2*i + 3            p = 2 * i + 3            # 从 p*p 开始标记,步长为 2p(只标记奇数倍数)            start = (p * p - 3) // 2            sieve[start::p] = [False] * ((len(sieve) - start - 1) // p + 1)    return [2] + [2 * i + 3 for i in range(len(sieve)) if sieve[i]]# 测试if __name__ == "__main__":    print("=== 筛法求素数 ===")    primes = sieve_of_eratosthenes(50)    print(f"2-50 之间的素数: {primes}")    print(f"共 {len(primes)} 个")    # 性能测试    import timeit    n = 1000000    t1 = timeit.timeit(lambda: sieve_of_eratosthenes(n), number=5)    t2 = timeit.timeit(lambda: sieve_optimized(n), number=5)    print(f"\n{n} 以内素数:")    print(f"  基础筛法: {t1:.4f}s")    print(f"  优化筛法: {t2:.4f}s")    print(f"  素数个数: {len(sieve_of_eratosthenes(n))}")

🔗 关联知识点

知识点
说明
range(start, stop, step)
带步长的 range
列表推导式过滤
[i for i in range() if condition]
嵌套循环
外层遍历素数,内层标记倍数
算法优化
只遍历到 sqrt(n),从 i*i 开始标记

题目三:打印菱形图案 ⭐⭐

📌 题目描述

编写函数 print_diamond(n),打印一个高度为 2n-1 行的菱形图案。

输入:n = 4输出:   *  *** ************ *****  ***   *

💡 编程思路

这道题考察 双重循环 + 字符串格式化

  1. 上半部分(包括中间行):行号 i 从 0 到 n-1

    • 前导空格:n - 1 - i 个
    • 星号:2 * i + 1 个
  2. 下半部分:行号 i 从 n-2 到 0(倒序)

    • 前导空格:n - 1 - i 个
    • 星号:2 * i + 1 个

关键技巧:使用 str.center() 或计算空格数量,使用字符串乘法 '*' * count 生成星号串。

🖥️ 参考代码

def print_diamond(n):    """打印菱形图案"""    if n <= 0:        return    # 上半部分(包括中间行)    for i in range(n):        spaces = ' ' * (n - 1 - i)        stars = '*' * (2 * i + 1)        print(spaces + stars)    # 下半部分    for i in range(n - 2, -1, -1):        spaces = ' ' * (n - 1 - i)        stars = '*' * (2 * i + 1)        print(spaces + stars)def print_diamond_center(n):    """使用 center 方法的简洁写法"""    width = 2 * n - 1    # 上半部分    for i in range(n):        line = '*' * (2 * i + 1)        print(line.center(width))    # 下半部分    for i in range(n - 2, -1, -1):        line = '*' * (2 * i + 1)        print(line.center(width))def print_diamond_oneliner(n):    """一行代码版本(推导式)"""    print('\n'.join(        ('*' * (2 * i + 1)).center(2 * n - 1)        for i in list(range(n)) + list(range(n - 2, -1, -1))    ))# 测试if __name__ == "__main__":    print("=== n = 3 ===")    print_diamond(3)    print("\n=== n = 5 ===")    print_diamond(5)    print("\n=== 使用 center 方法 ===")    print_diamond_center(4)    print("\n=== 一行代码版本 ===")    print_diamond_oneliner(3)

🔗 关联知识点

知识点
说明
range(n - 2, -1, -1)
倒序遍历
字符串乘法 '*' * n
快速生成重复字符
str.center(width)
字符串居中
双重循环
分别控制行和列
推导式 + join
一行生成多行输出

题目四:猜数字游戏(完整版) ⭐⭐⭐

📌 题目描述

实现一个完整的猜数字游戏,包含以下功能:

  1. 随机生成 1-100 之间的目标数字
  2. 玩家有 7 次猜测机会
  3. 每次猜测后提示「太大」「太小」或「猜对了」
  4. 记录猜测历史,避免重复猜测
  5. 游戏结束后显示统计信息
示例游戏过程:==================================🎮 欢迎来到猜数字游戏!我想了一个 1-100 之间的数字,你有 7 次机会==================================第 1 次尝试,请输入: 50📉 太小了!范围: 51-100第 2 次尝试,请输入: 75📈 太大了!范围: 51-74第 3 次尝试,请输入: 60📈 太大了!范围: 51-59第 4 次尝试,请输入: 55🎉 恭喜你!用了 4 次猜对了!猜测历史: [50, 75, 60, 55]

💡 编程思路

这道题综合考察 while 循环 + 条件判断 + 输入验证

  1. 游戏主循环
    :使用 while attempts < max_attempts 控制游戏轮数。
  2. 输入验证
    :使用 try-except 捕获非数字输入,使用条件判断验证范围。
  3. 历史记录
    :用列表存储猜测历史,用 in 检查是否重复猜测。
  4. 范围提示
    :维护 low 和 high 边界,根据猜测动态缩小范围。
  5. 提前退出
    :猜对时使用 break 退出循环。

🖥️ 参考代码

import randomdef guessing_game():    """猜数字游戏 - 完整版"""    secret = random.randint(1100)    max_attempts = 7    attempts = 0    history = []    low, high = 1100    print("=" * 50)    print("🎮 欢迎来到猜数字游戏!")    print(f"我想了一个 {low}-{high} 之间的数字,你有 {max_attempts} 次机会")    print("=" * 50)    while attempts < max_attempts:        print(f"\n范围: {low}-{high}")        # 获取有效输入        try:            guess_input = input(f"第 {attempts + 1} 次尝试,请输入: ").strip()            guess = int(guess_input)        except ValueError:            print("⚠️ 请输入有效的数字!")            continue        # 范围检查        if guess < low or guess > high:            print(f"⚠️ 请输入 {low}-{high} 范围内的数字!")            continue        # 重复猜测检查        if guess in history:            print(f"⚠️ 你已经猜过 {guess} 了,猜测历史: {history}")            continue        history.append(guess)        attempts += 1        # 判断结果        if guess < secret:            print(f"📉 太小了!")            low = guess + 1        elif guess > secret:            print(f"📈 太大了!")            high = guess - 1        else:            print(f"\n🎉 恭喜你!用了 {attempts} 次就猜对了!")            print(f"猜测历史: {history}")            # 评级            if attempts <= 3:                print("🏆 评级: 神级!")            elif attempts <= 5:                print("⭐ 评级: 优秀!")            elif attempts <= 7:                print("👍 评级: 良好!")            return    # 次数用完    print(f"\n😢 游戏结束!正确答案是 {secret}")    print(f"你的猜测: {history}")def guessing_game_auto(secret=42, guesses=None):    """自动测试版本(用于验证)"""    max_attempts = 7    attempts = 0    history = []    low, high = 1100    if guesses is None:        guesses = [50253742]  # 默认测试序列    for guess in guesses:        if attempts >= max_attempts:            return False"次数用尽"        if guess < low or guess > high:            return Falsef"{guess} 超出范围 {low}-{high}"        if guess in history:            return Falsef"{guess} 重复猜测"        history.append(guess)        attempts += 1        if guess == secret:            return Truef"{attempts} 次猜中"        elif guess < secret:            low = guess + 1        else:            high = guess - 1    return False"猜测列表用完但未猜中"# 测试if __name__ == "__main__":    # 自动测试    print("=== 自动测试 ===")    success, msg = guessing_game_auto(42, [50253742])    print(f"测试1: {success}{msg}")    success, msg = guessing_game_auto(99, [507588949799])    print(f"测试2: {success}{msg}")    # 交互式游戏(取消注释运行)    # guessing_game()

🔗 关联知识点

知识点
说明
while
 循环
条件控制的游戏主循环
try-except
输入验证和异常处理
break
猜对后提前退出
continue
无效输入时跳过本次迭代
random.randint
生成随机目标数字
边界维护
动态缩小搜索范围

题目五:FizzBuzz 的多种实现 ⭐⭐⭐

📌 题目描述

实现 FizzBuzz 问题:对于 1 到 n 的数字:

  • 能被 3 整除 → “Fizz”
  • 能被 5 整除 → “Buzz”
  • 同时被 3 和 5 整除 → “FizzBuzz”
  • 其他 → 数字本身
输入:n = 15输出:["1""2""Fizz""4""Buzz""Fizz""7""8"      "Fizz""Buzz""11""Fizz""13""14""FizzBuzz"]

💡 编程思路

FizzBuzz 是经典的面试题,考察条件判断的清晰度。多种实现方式对比:

  • 方法一(传统 if-elif)
    :最直观,先判断最特殊的(15),再判断一般的(3, 5)。
  • 方法二(字符串拼接)
    :利用 Python 的短路特性,"Fizz" * (i % 3 == 0) 条件为真时重复字符串。
  • 方法三(字典映射)
    :用字典存储因子和对应字符串,更易于扩展(如加入 7 → “Whizz”)。

🖥️ 参考代码

def fizzbuzz_traditional(n):    """方法一:传统 if-elif(最清晰)"""    result = []    for i in range(1, n + 1):        if i % 15 == 0:            result.append("FizzBuzz")        elif i % 3 == 0:            result.append("Fizz")        elif i % 5 == 0:            result.append("Buzz")        else:            result.append(str(i))    return resultdef fizzbuzz_concat(n):    """方法二:字符串拼接(Pythonic)"""    return [        "Fizz" * (i % 3 == 0) + "Buzz" * (i % 5 == 0or str(i)        for i in range(1, n + 1)    ]def fizzbuzz_dict(n, rules=None):    """方法三:字典映射(易于扩展)"""    if rules is None:        rules = {3"Fizz"5"Buzz"}    result = []    for i in range(1, n + 1):        parts = [word for factor, word in rules.items() if i % factor == 0]        result.append("".join(parts) or str(i))    return resultdef fizzbuzz_extended(n):    """扩展版本:3-Fizz, 5-Buzz, 7-Whizz"""    rules = {3"Fizz"5"Buzz"7"Whizz"}    return fizzbuzz_dict(n, rules)# 测试if __name__ == "__main__":    n = 20    print("=== 传统方法 ===")    print(fizzbuzz_traditional(n))    print("\n=== 字符串拼接 ===")    print(fizzbuzz_concat(n))    print("\n=== 字典映射 ===")    print(fizzbuzz_dict(n))    print("\n=== 扩展版本 (3,5,7) ===")    print(fizzbuzz_extended(n))    # 验证三种方法结果一致    assert fizzbuzz_traditional(100) == fizzbuzz_concat(100) == fizzbuzz_dict(100)    print("\n三种方法结果一致 ✓")    # 性能对比    import timeit    t1 = timeit.timeit(lambda: fizzbuzz_traditional(10000), number=100)    t2 = timeit.timeit(lambda: fizzbuzz_concat(10000), number=100)    t3 = timeit.timeit(lambda: fizzbuzz_dict(10000), number=100)    print(f"\n性能对比 (10000个数字, 100次):")    print(f"  传统方法: {t1:.4f}s")    print(f"  字符串拼接: {t2:.4f}s")    print(f"  字典映射: {t3:.4f}s")

🔗 关联知识点

知识点
说明
if/elif/else
多分支条件判断
字符串乘法 str * bool
Python 的短路技巧
or
 的默认值用法
A or B
,A 为空时返回 B
字典推导式过滤
[v for k, v in d.items() if cond]
可扩展设计
用字典存储规则,易于添加新规则

题目六:矩阵螺旋遍历 ⭐⭐⭐⭐

📌 题目描述

给定一个 m × n 的矩阵,返回其元素按螺旋顺序遍历的结果。

输入:matrix = [    [1, 2, 3],    [4, 5, 6],    [7, 8, 9]]输出:[123698745]解释:→ → →      ↓↑     ↓  ← ←

💡 编程思路

这道题是经典的边界收缩问题,考察对循环和边界的精确控制:

  1. 定义四个边界:top, bottom, left, right
  2. 按顺序遍历: 
    • 从左到右遍历 top 行,然后 top++
    • 从上到下遍历 right 列,然后 right--
    • 如果还有剩余行,从右到左遍历 bottom 行,然后 bottom--
    • 如果还有剩余列,从下到上遍历 left 列,然后 left++
  3. 重复直到所有元素被遍历

关键点:每次遍历一行/列后收缩边界,并在遍历前检查边界是否有效(防止重复遍历)。

🖥️ 参考代码

def spiral_order(matrix):    """    螺旋遍历矩阵 —— 边界收缩法    时间: O(m*n),空间: O(1)(不包括结果)    """    if not matrix or not matrix[0]:        return []    result = []    rows, cols = len(matrix), len(matrix[0])    # 定义边界    top, bottom = 0, rows - 1    left, right = 0, cols - 1    while top <= bottom and left <= right:        # 1. 从左到右遍历 top 行        for col in range(left, right + 1):            result.append(matrix[top][col])        top += 1        # 2. 从上到下遍历 right 列        for row in range(top, bottom + 1):            result.append(matrix[row][right])        right -= 1        # 3. 从右到左遍历 bottom 行(检查是否还有剩余行)        if top <= bottom:            for col in range(right, left - 1, -1):                result.append(matrix[bottom][col])            bottom -= 1        # 4. 从下到上遍历 left 列(检查是否还有剩余列)        if left <= right:            for row in range(bottom, top - 1, -1):                result.append(matrix[row][left])            left += 1    return resultdef spiral_order_simulation(matrix):    """模拟法:使用方向向量"""    if not matrix or not matrix[0]:        return []    rows, cols = len(matrix), len(matrix[0])    visited = [[False] * cols for _ in range(rows)]    # 方向:右、下、左、上    directions = [(01), (10), (0, -1), (-10)]    direction_idx = 0    row, col = 00    result = []    for _ in range(rows * cols):        result.append(matrix[row][col])        visited[row][col] = True        # 计算下一步        next_row = row + directions[direction_idx][0]        next_col = col + directions[direction_idx][1]        # 需要转向的情况:越界或已访问        if (next_row < 0 or next_row >= rows or             next_col < 0 or next_col >= cols or             visited[next_row][next_col]):            direction_idx = (direction_idx + 1) % 4            next_row = row + directions[direction_idx][0]            next_col = col + directions[direction_idx][1]        row, col = next_row, next_col    return resultdef generate_spiral_matrix(n):    """生成 n×n 的螺旋矩阵(逆向问题)"""    matrix = [[0] * n for _ in range(n)]    num = 1    top, bottom = 0, n - 1    left, right = 0, n - 1    while num <= n * n:        # 从左到右        for col in range(left, right + 1):            matrix[top][col] = num            num += 1        top += 1        # 从上到下        for row in range(top, bottom + 1):            matrix[row][right] = num            num += 1        right -= 1        # 从右到左        for col in range(right, left - 1, -1):            matrix[bottom][col] = num            num += 1        bottom -= 1        # 从下到上        for row in range(bottom, top - 1, -1):            matrix[row][left] = num            num += 1        left += 1    return matrix# 测试if __name__ == "__main__":    # 测试用例1:3x3    matrix1 = [        [123],        [456],        [789]    ]    print("=== 3x3 矩阵 ===")    print(f"原始矩阵:")    for row in matrix1:        print(f"  {row}")    print(f"螺旋遍历: {spiral_order(matrix1)}")    # 测试用例2:3x4    matrix2 = [        [1234],        [5678],        [9101112]    ]    print("\n=== 3x4 矩阵 ===")    print(f"螺旋遍历: {spiral_order(matrix2)}")    # 测试用例3:1x1    matrix3 = [[1]]    print(f"\n=== 1x1 矩阵 ===")    print(f"螺旋遍历: {spiral_order(matrix3)}")    # 生成螺旋矩阵    print("\n=== 生成 4x4 螺旋矩阵 ===")    spiral = generate_spiral_matrix(4)    for row in spiral:        print(f"  {row}")    # 验证:生成的矩阵螺旋遍历应该得到 1-16    assert spiral_order(spiral) == list(range(117))    print("验证通过 ✓")

🔗 关联知识点

知识点
说明
边界收缩
top++, bottom--, left++, right--
多方向遍历
右→下→左→上循环
range(start, stop, -1)
倒序遍历
边界检查
每次遍历前确认 top <= bottom
方向向量
使用 (dr, dc) 表示方向
逆向思维
螺旋遍历 ↔ 生成螺旋矩阵

总结:知识点覆盖矩阵

题目
难度
核心考察点
成绩等级判断器
if/elif/else
、边界测试、类型检查
素数筛选(筛法)
⭐⭐
嵌套循环、range 步长、列表推导式
打印菱形图案
⭐⭐
双重循环、字符串格式化、倒序 range
猜数字游戏
⭐⭐⭐
while
 循环、输入验证、break/continue、边界维护
FizzBuzz 多种实现
⭐⭐⭐
条件判断、字符串技巧、可扩展设计
矩阵螺旋遍历
⭐⭐⭐⭐
边界收缩、多方向循环、边界检查、逆向思维

建议:按顺序从第 1 题做到第 6 题。前 3 题巩固基础语法,第 4 题练习综合应用,第 5 题体会 Pythonic 写法,第 6 题是算法面试高频题,掌握边界收缩技巧对解决类似问题很有帮助。


延伸阅读

  • LeetCode 412. Fizz Buzz
  • LeetCode 204. 计数质数(埃拉托斯特尼筛法)
  • LeetCode 54. 螺旋矩阵
  • LeetCode 59. 螺旋矩阵 II

本文是《Python 全栈修炼之路》第 06 篇配套练习,欢迎点赞收藏!

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-03 08:13:02 HTTP/2.0 GET : https://f.mffb.com.cn/a/497525.html
  2. 运行时间 : 0.297530s [ 吞吐率:3.36req/s ] 内存消耗:5,476.00kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=18a66b70c1e7d751fa0fa19724eae498
  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.000386s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000787s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000298s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000258s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000480s ]
  6. SELECT * FROM `set` [ RunTime:0.000199s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000511s ]
  8. SELECT * FROM `article` WHERE `id` = 497525 LIMIT 1 [ RunTime:0.000831s ]
  9. UPDATE `article` SET `lasttime` = 1783037582 WHERE `id` = 497525 [ RunTime:0.035807s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.007351s ]
  11. SELECT * FROM `article` WHERE `id` < 497525 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.006064s ]
  12. SELECT * FROM `article` WHERE `id` > 497525 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.007650s ]
  13. SELECT * FROM `article` WHERE `id` < 497525 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.063982s ]
  14. SELECT * FROM `article` WHERE `id` < 497525 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.072601s ]
  15. SELECT * FROM `article` WHERE `id` < 497525 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.034155s ]
0.299035s