详解Python文件: .py、.ipynb、.pyi、.pyc、​.pyd !

文章介绍了Python的各种代码文件后缀,包括.py(源代码)、.ipynb(JupyterNotebook)、.pyi(类型提示)、.pyc(字节码)、.pyd(扩展模块)、.pyw(窗口化脚本)和.pyx(Cython源代码)。重点讲解了这些文件的作用和性能提升的应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天同事给我扔了一个.pyd文件,说让我跑个数据。然后我就傻了。。

不知道多少粉丝小伙伴会run .pyd代码文件?如果你也懵懵的,请继续往下读吧。。

今天科普下各类Python代码文件的后缀,给各位Python开发“扫扫盲”。

.py

最常见的Python代码文件后缀名,官方称Python源代码文件

不用过多解释了~

.ipynb

这个还是比较常见的,.ipynbJupyter Notebook文件的扩展名,它代表"IPython Notebook"。

学过数据分析,机器学习,深度学习的同学一定不陌生!

.pyi

.pyi文件是Python中的类型提示文件,用于提供代码的静态类型信息。

一般用于帮助开发人员进行类型检查静态分析

示例代码:

# hellp.pyi  
  
def hello(name: str) -> None:  
    print(f"hello {name}")  

.pyi文件的命名约定通常与相应的.py文件相同,以便它们可以被自动关联在一起。

.pyc

.pycPython字节码文件的扩展名,用于存储已编译的Python源代码的中间表示形式,因为是二进制文件所以我们无法正常阅读里面的代码。

.pyc文件包含了已编译的字节码,它可以更快地被Python解释器加载和执行,因为解释器无需再次编译源代码。

.pyd

.pydPython扩展模块的扩展名,用于表示使用CC++编写的二进制Python扩展模块文件。

.pyd文件是编译后的二进制文件,它包含了编译后的扩展模块代码以及与Python解释器交互所需的信息。

此外,.pyd文件通过import语句在Python中导入和使用,就像导入普通的Python模块一样。

由于CC++的执行速度通常比纯Python代码快,可以使用扩展模块来优化Python代码的性能,尤其是对于计算密集型任务。

.pyw

.pywPython窗口化脚本文件的扩展名。

它表示一种特殊类型的Python脚本文件,用于创建没有命令行界面(即控制台窗口)的窗口化应用程序。

一般情况下,运行Python脚本会打开一个命令行窗口,其中显示脚本输出和接受用户输入。但是,对于某些应用程序,如图形用户界面(GUI)应用程序,不需要命令行界面,而是希望在窗口中显示交互界面。这时就可以使用.pyw文件。

示例代码:

# click_button.pyw  
  
import tkinter as tk  
  
def button_click():  
    label.config(text="Button Clicked!")  
  
window = tk.Tk()  
button = tk.Button(window, text="Click Me", command=button_click)  
button.pack()  
  
label = tk.Label(window, text="Hello, World!")  
label.pack()  
  
window.mainloop()  

# .pyx

.pyxCython源代码文件的扩展名。

Cython是一种编译型的静态类型扩展语言,它允许在Python代码中使用C语言的语法和特性,以提高性能并与C语言库进行交互。

我对比了下Cython与普通python的运行速度:

fb.pyx(需使用cythonize命令进行编译)

import fb  
import timeit  
  
def fibonacci(n):  
if n <= 0:  
raise ValueError("n必须是正整数")  
  
if n == 1:  
return 0  
elif n == 2:  
return 1  
else:  
        a, b = 0, 1  
for _ in range(3, n + 1):  
            a, b = b, a + b  
return b  
  
# 纯Python版本  
python_time = timeit.timeit("fibonacci(300)", setup="from __main__ import fibonacci", number=1000000)  
  
# Cython版本  
cython_time = timeit.timeit("fb.fibonacci(300)", setup="import fb", number=1000000)  
  
print("纯Python版本执行时间:", python_time)  
print("Cython版本执行时间:", cython_time)  

run.py

import fb  
import timeit  
  
def fibonacci(n):  
if n <= 0:  
raise ValueError("n必须是正整数")  
  
if n == 1:  
return 0  
elif n == 2:  
return 1  
else:  
        a, b = 0, 1  
for _ in range(3, n + 1):  
            a, b = b, a + b  
return b  
  
# 纯Python版本  
python_time = timeit.timeit("fibonacci(300)", setup="from __main__ import fibonacci", number=1000000)  
  
# Cython版本  
cython_time = timeit.timeit("fb.fibonacci(300)", setup="import fb", number=1000000)  
  
print("纯Python版本执行时间:", python_time)  
print("Cython版本执行时间:", cython_time)  

得出结果:

纯Python版本执行时间: 12.391942400000516  
Cython版本执行时间: 6.574918199999956  

在这种计算密集任务情况下,Cython比普通Python效率快了近一倍。

本文转自网络,如有侵权,请联系删除。

学习资源推荐

除了上述分享,如果你也喜欢编程,想通过学习Python获取更高薪资,这里给大家分享一份Python学习资料。

这里给大家展示一下我进的兼职群和最近接单的截图

兼职群

私单

😝朋友们如果有需要的话,可以 V扫描下方二维码联系领取

学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

因篇幅有限,仅展示部分资料,添加上方即可获取
### argparse.pyi 文件与 argparse.py 和 argparse.pyc 的区别 #### 1. **argparse.py** `argparse.py` 是标准库中的源代码文件,包含了 `argparse` 模块的核心实现逻辑。它是纯 Python 编写的模块,定义了命令行参数解析的功能和行为[^1]。 #### 2. **argparse.pyc** `.pyc` 文件是由 `.py` 文件经过字节码编译后生成的缓存文件。它通常由解释器自动生成并存储在 `__pycache__` 目录下,用于加速程序运行时的加载速度。默认情况下,主脚本不会生成 `.pyc` 文件,但可以使用工具如 `py_compile` 或 `compileall` 手动创建它们[^1]。 #### 3. **argparse.pyi** `.pyi` 文件是一种特殊的文件类型,主要用于提供静态类型信息(type hints)。这种文件并不包含实际的函数或类实现,而是仅描述接口及其类型的声明。它的主要用途如下: - 提供 IDE 和静态分析工具(如 mypyPyright)所需的类型信息。 - 不影响运行时的行为,因为这些文件仅供开发工具读取。 - 对于像 `argparse` 这样的 C 实现扩展模块或者复杂的标准库模块来说尤为重要,因为它允许开发者通过 `.pyi` 文件获取详细的类型提示而无需查看底层实现细节。 以下是 `.pyi` 文件的一个简单例子: ```python def add_arguments(parser: ArgumentParser, *args: Any, **kwargs: Any) -> None: ... class ArgumentParser: def __init__(self, prog: str | None = ..., usage: str | None = ...) -> None: ... ``` 上述代码片段展示了如何在一个 `.pyi` 文件中为方法签名指定类型提示。 --- ### 原因:为何存在 argparse.pyi 而不是直接修改 argparse.py? 1. **性能考虑** 如果将所有的类型提示嵌入到原始 `.py` 文件中,则会增加额外的开销,尤其是在导入阶段可能会降低执行效率。因此,分离出单独的 `.pyi` 文件有助于保持核心功能简洁高效。 2. **兼容性和维护性** 部分模块可能是用 C 编写而成,在此情形下无法直接添加 Python 类型注解;此时借助 `.pyi` 可以为用户提供一致性的体验而不改变原有结构。 3. **支持动态特性丰富的项目** 动态特性强的语言往往难以完全依赖单一形式表达所有语义,所以采用独立方式补充说明更灵活实用。 --- ### 总结 综上所述,虽然三者都关联着同一个命名空间下的组件——即 `argparse` 模块本身,但是各自扮演的角色却截然不同:一个是具体业务逻辑载体(`argparse.py`);另一个负责提升启动效能(`argparse.pyc`);最后一个则是服务于现代软件工程实践里至关重要的部分—增强可读性和协作能力(`argparse.pyi`)。 相关问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值