Python 详解文件 < ①.py,②.ipynb,③.pyi,④.pyc,⑤.pyd,⑥.pyw,⑦.pyx >

文章介绍了Python的各种代码文件后缀,包括.py用于源代码,.pyc是编译后的字节码,.pyd是Windows下的二进制扩展模块,还提到了Cython的.pyx文件用于性能优化。此外,文章提到了类型提示文件.pyi和无命令行界面的.pyw文件。

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

今天有人给我扔了一个.pyd文件,说让我跑个数据,然后我就傻了…,不知道多少粉丝小伙伴会run.pyd代码文件?如果你也懵懵的,请继续往下读!

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

###  --------------------------------- .相关文件名后缀《全》 --------------------------------- 
.py:这通常是您编写的输入源代码。

.py3: Python3脚本(Python3脚本通常以.py而不是.py3结尾,很少使用)

.pyc:这是编译好的字节码。如果您导入一个模块,python将生成一个*.pyc包含字节码的文件,以便以后再次导入它更容易(也更快).pyc二进制文件可以反编译成.py文件,反编译软件叫Easy Python Decompiler。

.pyo:这是在优化(-O)时创建的*.pyc文件,从Python3.5开始,Python将只使用pyc而不是pyo和pyc

.pyd:这基本上是一个Windows DLL文件。

.pyi : MyPy存根,存根文件(PEP 484.

.pyw : 用pythonw.exe执行的Windows的Python脚本

.pyx : 将Cython src转换为C/C++

.pyz : Python脚本归档(PEP 441)(这是一个包含标准Python脚本头之后的二进制形式的压缩Python脚本(ZIP)的脚本)

.pywz : 用于MS-Windows的Python脚本归档(PEP 441)(这是一个包含标准Python脚本头之后的二进制形式的压缩Python脚本(ZIP)的脚本)

.py [cod] : .gitignore中的通配符表示该文件可能是.pyc,.pyo或.pyd

.rpy : 包含应用程序或框架特定功能的RPython脚本或Python脚本

.pyde : 处理使用的Python脚本

.pyp : Py4D Python插件

.pyt : Python声明文件

--------------------------------- .py ---------------------------------

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

在这里就不用过多解释了~

--------------------------------- .ipynb ---------------------------------

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

在这里插入图片描述

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

--------------------------------- .pyi ---------------------------------

.pyi文件是Python中的类型提示文件,用于提供代码的静态类型信息。
一般用于帮助开发人员进行类型检查和静态分析。

# -*- coding: utf-8 -*-
# @Time    : 2023/07/28 12:13
# @Author  : 微酷
# @Email   : 110169011@qq.com
# @FileName: 提示.pyi
# @Software: PyCharmPro2021.3; Anaconda(Python3.10)

hellp.pyi

def hello(name: str) -> None:
    print(f"hello {name}")

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

--------------------------------- .pyc ---------------------------------

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

在这里插入图片描述

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

--------------------------------- .pyd ---------------------------------

.pyd是Python扩展模块的扩展名,用于表示使用C或C++编写的二进制Python扩展模块文件。.pyd文件是编译后的二进制文件,它包含了编译后的扩展模块代码以及与Python解释器交互所需的信息。

  1. 此外,.pyd文件通过import语句在Python中导入和使用,就像导入普通的Python模块一样。
  2. 由于C或C++的执行速度通常比纯Python代码快,可以使用扩展模块来优化Python代码的性能,尤其是对于计算密集型任务。
    在这里插入图片描述

--------------------------------- .pyw ---------------------------------

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

  • 一般情况下,运行Python脚本会打开一个命令行窗口,其中显示脚本输出和接受用户输入。但是,对于某些应用程序,如图形用户界面(GUI)应用程序,不需要命令行界面,而是希望在窗口中显示交互界面。这时就可以使用.pyw文件。
# -*- coding: utf-8 -*-
# @Time    : 2023/07/30 12:13
# @Author  : 微酷
# @Email   : 110169011@qq.com
# @FileName: click_button.pyw
# @Software: PyCharmPro2021.3; Anaconda(Python3.10)

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 ---------------------------------

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

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

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

cdef int a, b, i

def fibonacci(n):
if n <= 0:
raise ValueError("n必须是正整数")

if n == 1:
return 0
elif n == 2:
return 1
else:
        a = 0
        b = 1
for i in range(3, n + 1):
            a, b = b, a + b
return b

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效率快了近一倍。

免责声明:本篇文章提供的一切软件、教程和内容信息仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本信息来自网络收集整理,版权争议与本人无关。我们非常重视版权问题,如有侵权请私信与我联系,敬请谅解!

### 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
发出的红包

打赏作者

WK-良人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值