当前位置:首页>python>大模型学习 Java程序员转Python真实踩坑记录

大模型学习 Java程序员转Python真实踩坑记录

  • 2026-03-12 02:10:52
大模型学习 Java程序员转Python真实踩坑记录

最近都忙于项目,有段时间没有更新了。今天把我自己学习的部分笔记整理分享给大家,希望能帮有缘人节约学习时间。

公司今年战略转型AI,Python成了大模型开发的必备技能。作为一个老牌Java程序员,被迫转型Python,心态崩过、质疑过,但最后还是真香了。这篇文章记录了我用Java思维理解Python的过程,希望给同样在转型的朋友们一点帮助。


为什么要写这篇

公司All in AI后,所有新项目必须用Python。从抵触到接受,再到效率提升3倍,中间踩了太多坑。

为什么Java程序员学Python这么痛苦

  • 没有类型声明,写代码心里没底
  • 缩进代替花括号,强迫症要命
  • 语法太简洁,总觉得不够"正式"

但真实对比后

  • 写个数据处理脚本:Java 200行,Python 20行
  • 调个大模型API:Java要解决依赖冲突,Python直接import
  • 快速验证想法:Java还在搭环境,Python已经跑起来了

如果你也在转型,这些坑和对比经验,应该能帮你少走弯路。用Java类比着学,理解速度快10倍。


一、最痛苦的坑(刚开始)

1. 缩进报错

ifTrue:print("hello")  # IndentationError

第一反应:什么鬼?缩进错了也能运行?

真相:Python用缩进代替花括号,混用Tab和空格必挂。

经验

  • 配置编辑器,Tab自动转4个空格
  • 刚开始经常出现缩进错误,习惯后反而觉得清晰
  • 后来,看Java的满屏花括号觉得累

2. 没有分号

name = "张三"age = 25

第一反应:不加封号,怎么知道一行结束了?

真相:Python用换行判断语句结束

适应期:3天,之后觉得Java的分号多余


3. count++报错

count = 0count++  # SyntaxError

第一反应:连++都不支持?

真相:Python没有++运算符,只能count += 1

踩坑场景:肌肉记忆,经常写i++,然后报错


4. 变量没有类型

刚开我这样写:

name = "张三"age = 25

然后到处调用,IDE也不提示类型,心里慌得一批。

真相:Python 3.10+ 有类型提示,只是可选的

name: str = "张三"age: int = 25defcalculate(salary: float) -> float:return salary * 1.2

经验

  • 前期加上类型提示(帮助理解)
  • 用mypy做类型检查(类似Java编译器)

5. 负索引让我怀疑人生

names = ["张三""李四""王五"]print(names[-1])  # 输出"王五"

第一反应:数组越界了?

真相:Python支持负索引,-1 表示最后一个,-2 表示倒数第二个

真实使用场景

# 获取文件扩展名filename = "data.xlsx"ext = filename.split(".")[-1]  # xlsx# Java写法String ext = filename.substring(filename.lastIndexOf(".") + 1);

适应期:3天,之后觉得真香


6. 列表没有size()

names = ["张三""李四"]length = len(names)  # 不是names.size()

第一反应:为什么不是方法?

真相:Python用len()函数,不是方法

经验:统一用len(),适用于所有容器(list、dict、set、str)


7. 字典访问报KeyError

scores = {"张三"85}score = scores["李四"]  # KeyError: '李四'

踩坑场景:从API解析JSON,某个字段不存在就崩了

正确姿势

# 安全访问(不会报错)score = scores.get("李四")        # Nonescore = scores.get("李四"0)     # 0(默认值)

类比Javaget(key, default) = getOrDefault(key, default)


8. 循环中删除元素

numbers = [1223]for num in numbers:if num == 2:        numbers.remove(num)  # 会漏删一个2

踩坑场景:过滤列表元素,结果漏删了

正确姿势

# 列表推导式(推荐)numbers = [num for num in numbers if num != 2]

经验:循环中不要修改列表,用推导式创建新列表


9. 列表拷贝是引用

a = [123]b = ab.append(4)print(a)  # [1, 2, 3, 4] ← a也被修改了!

踩坑场景:拷贝列表做备份,结果修改备份影响了原列表

正确姿势

a = [123]b = a.copy()  # 或 b = a[:]b.append(4)print(a)  # [1, 2, 3]

10. 可变默认参数

deffunc(items=[]):    items.append(1)return itemsprint(func())  # [1]print(func())  # [1, 1] ← 意外!

踩坑场景:函数默认参数是空列表,第二次调用居然不是空的

真相:默认参数只创建一次(坑!)

正确姿势

deffunc(items=None):if items isNone:        items = []    items.append(1)return items

经验:默认参数用None,不要用可变对象(list、dict、set)


二、数据结构对比

2.1 列表(List)= Java的ArrayList

Java写法

List<String> names = new ArrayList<>();names.add("张三");names.add("李四");names.add(0"王五");  // 插入到开头names.remove(1);  // 删除索引1的元素String first = names.get(0);int size = names.size();boolean contains = names.contains("张三");

Python写法

names = ["张三""李四"]  # 创建names.append("王五")       # 添加names.insert(0"赵六")    # 插入到开头first = names[0]           # 访问last = names[-1]           # 最后一个(负索引)names.pop(1)               # 删除索引1的元素length = len(names)        # 长度contains = "张三"in names # 包含判断

几个关键区别

  • append 不是 add
  • pop 不是 remove(remove是按值删除)
  • len() 不是 .size()
  • 支持负索引(-1表示最后一个)

2.2 列表切片:比Java强大10倍

Python写法

numbers = [0123456789]print(numbers[2:5])    # [2, 3, 4](不包含5)print(numbers[:3])     # [0, 1, 2](前3个)print(numbers[7:])     # [7, 8, 9](从索引7到最后)print(numbers[::2])    # [0, 2, 4, 6, 8](每隔1个)print(numbers[::-1])   # [9, 8, 7, 6, 5, 4, 3, 2, 1, 0](反转)

Java写法(需要手动实现)

List<Integer> numbers = Arrays.asList(0123456789);// 只能用subListList<Integer> sub = numbers.subList(25);  // [2, 3, 4]// 反转需要Collections.reverse()// 其他切片功能需要手动实现

经验

  • 切片不会越界(Java会)
  • 切片是Python最强特性之一
  • 适应后写代码速度快5倍

2.3 字典(Dict)= Java的HashMap

Java写法

Map<String, Integer> scores = new HashMap<>();scores.put("张三"85);scores.put("李四"90);int score = scores.get("张三");int defaultScore = scores.getOrDefault("王五"0);boolean hasKey = scores.containsKey("张三");scores.remove("李四");int size = scores.size();for (Map.Entry<String, Integer> entry : scores.entrySet()) {    System.out.println(entry.getKey() + ": " + entry.getValue());}

Python写法

scores = {"张三"85"李四"90}scores["王五"] = 95# 添加/修改score = scores["张三"]       # 访问(不存在会报错)score = scores.get("赵六"0# 安全访问(不存在返回0)has_key = "张三"in scores   # 检查key是否存在del scores["李四"]           # 删除size = len(scores)           # 长度for name, score in scores.items():    print(f"{name}{score}")

关键区别

  • dict[key] = value 而不是 put
  • dict[key] 不存在会报KeyError(坑!)
  • get(key, default)安全访问(类似getOrDefault)
  • items()遍历键值对

2.4 列表推导式:从抗拒到真香

刚开始觉得奇怪

squares = [x**2for x in range(10if x % 2 == 0]

理解后觉得简洁10倍

# Java写法List<Integer> squares = new ArrayList<>();for (int x = 0; x < 10; x++) {if (x % 2 == 0) {        squares.add(x * x);    }}# Python写法(简洁10倍)squares = [x**2for x in range(10if x % 2 == 0]

经验:不要一开始就追求Pythonic,先用for循环写,自然就进化成推导式了


三、面向对象对比

3.1 类定义

Java写法

publicclassUser{private String name;privateint age;publicUser(String name, int age){this.name = name;this.age = age;    }public String getName(){return name;    }public String introduce(){return"我是" + name + ",今年" + age + "岁";    }}

Python写法

classUser:def__init__(self, name, age):# 构造函数        self.name = name        self.age = agedefget_name(self):# 方法(第一个参数必须是self)return self.namedefintroduce(self):returnf"我是{self.name},今年{self.age}岁"

关键区别

  • __init__ 是构造函数
  • self 相当于 this,但必须显式写
  • 不需要显式声明成员变量
  • 不需要new关键字

3.2 继承与多态

Java写法

publicclassAnimal{protected String name;publicAnimal(String name){this.name = name;    }publicvoidspeak(){        System.out.println(name + "发出声音");    }}publicclassDogextendsAnimal{publicDog(String name){super(name);    }@Overridepublicvoidspeak(){        System.out.println(name + "说:汪汪汪");    }}

Python写法

classAnimal:def__init__(self, name):        self.name = namedefspeak(self):        print(f"{self.name}发出声音")classDog(Animal):# 括号中写父类def__init__(self, name):        super().__init__(name)  # 调用父类构造函数defspeak(self):# 不需要@Override注解        print(f"{self.name}说:汪汪汪")

关键区别

  • class Child(Parent) 继承语法
  • super().__init__() 调用父类构造函数
  • 方法重写不需要 @Override

3.3 访问控制

Java写法

publicclassUser{private String password;  // 真私有protectedint age;         // 保护public String name;        // 公开}

Python写法

classUser:def__init__(self):        self.name = "张三"# 公开        self._age = 25# 保护(约定)        self.__id = 0# 私有(名称改写)

第一反应:没有private,安全性怎么保证?

真相:Python的访问控制是约定,不是强制

经验

  • 单下划线_:约定外部不访问(实际能访问)
  • 双下划线__:名称改写(更难访问,但还是能访问)
  • Python哲学:都是成年人,遵守约定即可

四、文件操作真香

4.1 with语句:自动关闭文件

Java写法

try (BufferedReader reader = new BufferedReader(new FileReader("data.txt"))) {    String line;while ((line = reader.readLine()) != null) {        System.out.println(line);    }}

Python写法

with open("data.txt""r", encoding="utf-8"as f:for line in f:        print(line.strip())

经验

  • with语句自动关闭文件,不需要finally
  • 必须加encoding="utf-8"(否则中文乱码)
  • 比Java简洁5倍

五、选择困难症

Java还是Python?

做了个Excel数据处理工具,对比了一下:

Java版本

  • 代码:200行
  • 开发时间:2天
  • 性能:30秒
  • 依赖冲突:花半天解决

Python版本(用Pandas)

  • 代码:20行
  • 开发时间:5小时
  • 性能:3秒(Pandas底层用C)
  • 依赖冲突:无

我的选择

快速原型 → Python数据处理 → PythonAI开发 → Python核心业务 → Java高并发 → Java大型系统 → Java

真实案例

  • 做AI Demo:用Python,1天搞定
  • 做线上支付系统:用Java,稳

六、踩过的10个最痛的坑(排名)

1. 可变默认参数(坑惨了)

# ❌ 错误deffunc(items=[]):    items.append(1)return items# ✅ 正确deffunc(items=None):if items isNone:        items = []    items.append(1)return items

2. 列表拷贝是引用

# ❌ 错误a = [123]b = a  # 这是引用b.append(4)  # a也被修改# ✅ 正确b = a.copy()  # 或 b = a[:]

3. 循环中删除元素

# ❌ 错误for item in items:    items.remove(item)  # 会漏删# ✅ 正确items = [x for x in items if condition]

4. 文件没关闭

# ❌ 忘记关闭f = open("file.txt")# ✅ 自动关闭with open("file.txt"as f:# ...

5. 异常被吞掉

# ❌ 捕获所有异常(包括KeyboardInterrupt)except:pass# ✅ 只捕获Exceptionexcept Exception as e:    print(e)

6. KeyError崩溃

# ❌ 不存在会报错score = scores["李四"]# ✅ 安全访问score = scores.get("李四"0)

7. 负索引越界

# ❌ 负索引可能越界last = items[-1]  # 空列表会报错# ✅ 检查长度if items:    last = items[-1]

8. 肌肉记忆写i++

# ❌ Java习惯i++  # SyntaxError# ✅ Python写法i += 1

9. 缩进混用Tab和空格

# ❌ 混用Tab和空格deffunc():ifTrue:  # Tab        print("hello")  # 空格# ✅ 统一用4个空格deffunc():ifTrue:        print("hello")

10. 编码问题

# ❌ 中文乱码with open("file.txt""r"as f:    content = f.read()# ✅ 指定编码with open("file.txt""r", encoding="utf-8"as f:    content = f.read()

七、工具推荐

IDE

PyCharm(类似IntelliJ IDEA)

  • 自动提示类型错误
  • 自动格式化
  • 调试功能强大

自动化工具

# 自动格式化(必装)pip install blackblack your_file.py# 类型检查(必装)pip install mypymypy your_file.py

总结

Python比Java强的地方

  1. 开发速度快3-5倍(脚本、数据处理、AI)
  2. 生态太强(几乎所有新库都有Python版本)
  3. 语法简洁(少写70%的样板代码)

Java比Python强的地方

  1. 性能(Java快2-10倍)
  2. 类型安全(编译时检查)
  3. 大型项目(微服务、企业级应用)

我的最终选择

工具箱:- 快速原型 → Python- 数据处理 → Python- AI开发 → Python- 核心业务 → Java- 高并发系统 → Java最优解:双修,根据场景选择

最后一句:Python不是要取代Java,而是多一把武器。工具箱里的工具越多,解决问题的能力越强。可能文中有些内容并不完美,也希望各位朋友帮在留言区指正,一起进步!

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-03-28 02:56:38 HTTP/2.0 GET : https://f.mffb.com.cn/a/479218.html
  2. 运行时间 : 0.201322s [ 吞吐率:4.97req/s ] 内存消耗:5,215.08kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=f2ba3b3661483dc36f03ff498f345bd0
  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.001093s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001523s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000716s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000632s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000474s ]
  6. SELECT * FROM `set` [ RunTime:0.000198s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000495s ]
  8. SELECT * FROM `article` WHERE `id` = 479218 LIMIT 1 [ RunTime:0.000488s ]
  9. UPDATE `article` SET `lasttime` = 1774637798 WHERE `id` = 479218 [ RunTime:0.013697s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000435s ]
  11. SELECT * FROM `article` WHERE `id` < 479218 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000518s ]
  12. SELECT * FROM `article` WHERE `id` > 479218 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000538s ]
  13. SELECT * FROM `article` WHERE `id` < 479218 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.004954s ]
  14. SELECT * FROM `article` WHERE `id` < 479218 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.001077s ]
  15. SELECT * FROM `article` WHERE `id` < 479218 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.005854s ]
0.203269s