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

本文科普了Python中的各种代码文件后缀,如.py(源码)、.ipynb(JupyterNotebook)、.pyi(类型提示)、.pyc(字节码)、.pyd(扩展模块)、.pyw(无窗口脚本)和.pyx(Cython源码),并强调了它们在开发过程中的作用和性能差异。
该文章已生成可运行项目,

今天同事给我扔了一个.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所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。

img
img

二、Python必备开发工具

工具都帮大家整理好了,安装就可直接上手!img

三、最新Python学习笔记

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。

img

四、Python视频合集

观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

img

五、实战案例

纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

img

六、面试宝典

在这里插入图片描述

在这里插入图片描述

简历模板在这里插入图片描述
若有侵权,请联系删除
本文章已经生成可运行项目
<think>我们正在解决pyinstaller出现"error: unrecognized arguments: hello.py"错误的问题。根据引用[5],用户在使用pyinstaller命令时遇到类似错误:`pyinstaller: error: unrecognized arguments:*.py`。该引用提到,用户可能在命令提示行中使用了不正确的命令格式。 观察错误信息:"error: unrecognized arguments: hello.py",这表明pyinstaller无法识别我们提供的参数"hello.py"。通常,这是因为在命令中使用了错误的选项或格式。 标准的使用pyinstaller打包单个文件的命令为: ``` pyinstaller -F hello.py ``` 其中,`-F`表示生成单个可执行文件(one-file),后面紧跟要打包的Python脚本文件名。 如果用户直接使用`pyinstaller hello.py`,这是pyinstaller的默认模式(生成一个文件夹),不会报错。但是,如果用户使用了其他选项,并且选项和文件名的位置不正确,则可能出现此错误。 根据引用[5]的提示,用户需要确保在命令提示行中正确切换到目标文件所在的目录,然后使用正确的命令格式。 因此,解决步骤可能如下: 1. 打开命令提示符(cmd)或PowerShell。 2. 使用`cd`命令切换到包含`hello.py`的目录。 3. 执行正确的打包命令:`pyinstaller -F hello.py` 如果问题仍然存在,则可能是由于pyinstaller安装问题或版本问题。根据引用[2]和引用[3],可以尝试重新安装pyinstaller或者使用本地安装。此外,引用[3]中提到了修改源代码的方法,但此方法可能是针对特定错误的,我们的错误与之不同,因此暂时不考虑。 因此,我们给出以下解决方案: **解决方案:** 步骤1: 检查命令格式 确保命令格式正确,使用`pyinstaller -F hello.py`(注意:`-F`和`hello.py`之间有一个空格,且`hello.py`前面没有其他选项)。 步骤2: 如果命令格式正确但问题依旧,尝试重新安装pyinstaller 使用以下命令卸载并重新安装pyinstaller: ``` pip uninstall pyinstaller pip install pyinstaller ``` 步骤3: 如果重新安装后问题仍然存在,尝试使用pyinstaller的较新版本或较稳定版本。可以通过指定版本号安装,例如: ``` pip install pyinstaller==4.10 ``` 步骤4: 如果上述步骤无效,考虑引用[3]中提到的修改源码的方法,但我们的错误信息与之不同,因此不太适用。此时,可以尝试在pyinstaller命令前加上`python -m`,即: ``` python -m PyInstaller -F hello.py ``` 注意:使用`python -m`可以确保使用当前Python环境中的PyInstaller模块,避免路径问题。 根据以上步骤,用户应该能够解决"unrecognized arguments"错误。 此外,引用[1]和引用[4]提到的问题与当前问题关联不大,因此我们暂时不考虑。 总结:首先检查命令格式,然后尝试重装pyinstaller,最后尝试使用`python -m`方式运行。 生成相关问题: 1. 如何正确使用pyinstaller打包Python脚本? 2. 安装pyinstaller时遇到错误该如何解决? 3. pyinstaller打包过程中出现其他错误(如模块找不到)如何解决? </think>### 解决PyInstaller "error: unrecognized arguments: hello.py" 的方法 该错误通常由**命令格式不正确**或**环境配置问题**引起。以下是具体解决步骤: #### 步骤1:检查命令格式(关键) ```bash # 错误示例(缺少主命令): pyinstaller hello.py # 正确格式(必须包含主命令 -- 短横线不可省略): pyinstaller --onefile hello.py # 标准写法 # 或简写: pyinstaller -F hello.py # -F 是 --onefile 的缩写 ``` > 注意:`pyinstaller` 命令后必须接选项(如 `-F` 或 `--onefile`),不可直接跟文件名。参考错误类型与引用[5]相同[^5]。 #### 步骤2:验证文件路径 ```bash # 进入脚本所在目录再执行 cd /d C:\your\script\path pyinstaller -F hello.py ``` > 避免路径包含中文或特殊字符,建议使用纯英文路径。 #### 步骤3:重装PyInstaller ```bash # 卸载当前版本 pip uninstall pyinstaller # 安装兼容版本(Python 3.7+推荐) pip install pyinstaller==5.13.0 ``` > 若安装报错(如引用[2]的metadata错误),先更新工具链: > `pip install --upgrade pip setuptools wheel`[^2] #### 步骤4:检查Python环境 ```bash # 确认使用的Python解释器 where python # 验证PyInstaller关联 pyinstaller --version ``` > 若存在多个Python版本,使用绝对路径: > `C:\Python39\python.exe -m PyInstaller -F hello.py` #### 备用方案:源码修改(慎用) 如上述步骤无效,尝试修改PyInstaller源码(参考引用[3]): 定位文件:`...\PyInstaller\loader\pyi_carchive.py` 将第85行附近代码修改为: ```python # 原代码:toc = Toc(filename) toc = Toc(filename.encode('utf-8')) # 显式编码处理[^3] ``` ### 常见触发场景 1. **空格使用错误**:`pyinstaller-F hello.py`(缺少空格) 2. **过时版本**:PyInstaller 3.x 与 Python 3.10+存在兼容问题 3. **路径包含空格**:`C:\My Project\` 需加引号:`pyinstaller -F "C:\My Project\hello.py"` > 通过上述步骤,90%以上的同类错误可解决。若问题依旧,建议提供完整的终端错误截图进一步分析。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值