python文件:py,ipynb, pyi, pyc, pyd, pyo都是什么文件?

news2025/1/15 11:56:31

在这里插入图片描述

1、Python文件类型介绍 📁

1.1 .py 文件:源代码基础

.py 文件是 Python 最基本的源代码文件格式,用于存储纯文本形式的 Python 代码。它是开发者编写程序的主要场所,包含函数、类、变量定义以及执行逻辑。Python 解释器直接读取并执行 .py 文件中的指令。例如 ,创建一个简单的 hello.py 文件 ,内容如下:

print("Hello, Python World!")

运行此文件 ,输出结果为:

Hello, Python World!

1.2 .ipynb 文件:Jupyter Notebook交互式编程

.ipynb 文件是 Jupyter Notebook 的专用格式,它允许用户在一个网页应用中混合编写 Markdown 文本、执行代码、查看输出结果及图表。这种交互式环境特别适合数据科学、教学和快速原型设计。例如 ,在 Jupyter Notebook 中 ,可以这样编写:

# In[1]:
import numpy as np
arr = np.array([1, 2, 3])
arr * 2

输出结果直接显示在下方单元格:

array([2, 4, 6])

1.3 .pyi 文件:类型提示信息

.pyi 文件用于存储静态类型信息,帮助静态分析工具和IDE更好地理解Python代码的结构,提供代码补全、类型检查等功能。这是Python逐步向静态类型语言特性靠拢的一个体现。例如,为一个模块创建类型提示文件 mymodule.pyi

from typing import List

def process_data(data: List[int]) -> int:
    ...

1.4 .pyc 文件:编译后的字节码

当 Python 解释器首次导入 .py 文件时,会将其编译成字节码并保存为 .pyc 文件,以加快后续的导入速度。这些文件通常存储在 __pycache__ 目录下,具有特定的命名规则 ,如 module.cpython-311.pyc。这一步骤对开发者透明 ,但了解其机制有助于理解Python的加载流程。

1.5 .pyd 文件:Python扩展模块(Windows)

.pyd 文件是Windows平台上Python的动态链接库(DLL),用于封装用C/C++编写的Python扩展模块。它们提供了访问底层系统功能或提升性能的途径。在Linux和macOS上 ,这类文件以 .so(共享对象)的形式存在。创建 .pyd 需要使用Python的C API和编译工具链。

1.6 .pyo 文件:优化编译后的代码(Python 3.8-已弃用)

在Python 3.8之前 ,通过 -O 选项编译 .py 文件会产生 .pyo 文件 ,这是对字节码进行简单优化的产物 ,主要用于去除断言和 __debug__ 代码块。然而 ,自Python 3.8起,该功能已被移除,鼓励使用更高级的优化手段和工具,如PyPy解释器或第三方优化库。

2、.py 文件深入解析 🐍

2.1 编写规范与最佳实践

遵循PEP 8风格指南是编写高质量Python代码的关键。这包括但不限于合理命名(如使用小写字母和下划线命名变量)、限制行宽至79字符、适当使用空行和空格等。例如,下面的代码片段展示了良好的代码风格:

def calculate_total(quantity, price):
    """Calculate the total cost given quantity and price."""
    return quantity * price

total_cost = calculate_total(10, 9.99)
print(total_cost)

2.2 模块导入机制详解

Python的模块导入遵循层次化路径搜索策略。首先查找内置模块,然后是当前目录 ,接着是环境变量PYTHONPATH指定的目录 ,最后是标准库路径。使用绝对导入(如 import math)优于相对导入,以增强代码可读性和移植性。利用 __init__.py 文件可以使目录成为包,支持包内模块的导入。

2.3 .py 文件的版本控制策略

.py 文件纳入Git等版本控制系统时 ,应忽略 .pyc.pyo__pycache__ 目录,以免引入不必要的二进制差异。利用 .gitignore 文件配置如下:

# .gitignore
*.py[cod]
__pycache__/

此外,通过注释或文档字符串记录每次提交的重大更改 ,有助于团队协作和后期维护。

2.4 从 .py 到可执行文件的打包方法

将Python脚本转换为独立可执行文件,便于分发和部署,常用工具有PyInstaller、cx_Freeze和py2exe。以PyInstaller为例 ,安装后,只需一行命令即可生成可执行文件:

pip install pyinstaller
pyinstaller --onefile your_script.py

这会在dist/your_script目录下生成一个无需Python环境即可运行的可执行文件。这种方式适合制作跨平台应用,简化了部署流程。

3、Jupyter Notebook (.ipynb) 实战技巧 📓

3.1 交互式数据分析与可视化

Jupyter Notebook 支持即时代码执行,非常适合数据分析任务。结合Pandas处理数据 ,Matplotlib或Seaborn进行可视化,能够迅速洞察数据模式。例如,加载 Iris 数据集并绘制散点图:

import pandas as pd
import seaborn as sns
sns.set_theme(style="whitegrid")
iris = sns.load_dataset("iris")
sns.pairplot(iris, hue="species")

此段代码将生成展示Iris数据集中各属性间关系的交互式散点图矩阵。

3.2 Notebook转换与分享

Jupyter Notebook 可以导出为多种格式,便于分享与归档。使用菜单栏的“文件”->“下载为”,可选择 .html, .pdf, .markdown, .python 等格式。若需在线分享,Jupyter Notebook 可上传至 nbviewer.jupyter.org 或托管于 GitHub 并利用 GitHub Pages 展示。

3.3 高效 Notebook 管理与调试

  • 版本控制:利用 Git 管理 Notebook,记录每一次迭代,方便回溯和协作。
  • 魔术命令:利用 %history 查看命令历史 ,%timeit 测量代码块执行时间,提高效率。
  • 单元格管理:快捷键(如 Esc 进入命令模式,Shift + Enter 执行并跳转到下一单元格)和单元格类型切换(Code、Markdown)使编辑更为流畅。
  • 调试:虽然Jupyter原生不支持断点调试,但可以使用 %debug 魔术命令在异常后进入交互式调试器 ,或借助第三方扩展如 ipdb

3.4 从 .ipynb 到 .py 脚本的转换技巧

将 Notebook 转换为 Python 脚本,便于在非交互环境中运行或作为模块重用。使用 jupyter nbconvert 命令行工具:

jupyter nbconvert --to script your_notebook.ipynb

这会生成一个名为 your_notebook.py 的文件,其中包含 Notebook 中的所有代码 ,按执行顺序排列 ,且去除了Markdown和代码输出。为了保持代码的可读性和文档性,可手动整理转换后的脚本,添加必要的注释和模块导入语句。

4、类型提示与.pyi文件运用 🔍

4.1 类型提示基础与进阶

类型提示(Type Hints)自Python 3.5引入,通过PEP 484标准化,旨在提高代码的可读性和维护性。基础类型提示如:

def greet(name: str) -> str:
    return f"Hello, {name}!"

这里,name 参数被标注为 str 类型 ,函数返回值预期为 str 类型。进阶用法包括使用 List, Dict, Optional, 以及自定义类等复杂类型,以及利用 Union, Literal, TypeVar 等类型操作符。

4.2 自动生成类型提示文件

对于大型项目 ,手动编写类型提示可能繁琐。工具如 mypy, stubgen(来自typing_extensions库的一部分)可自动生成 .pyi 文件。例如,使用 stubgen 自动生成模块的类型提示:

stubgen my_module.py

这会在当前目录下创建 my_module.pyi 文件,包含了模块的类型信息。

4.3 利用类型提示提升代码质量

类型提示不仅帮助IDE提供更好的自动完成和错误检查,还能在团队协作中减少因类型错误导致的bug。通过静态类型检查(如使用Mypy),在编码阶段就能发现潜在类型不匹配问题,加速开发流程,提高软件质量。

4.4 类型检查工具与集成

  • Mypy 是最流行的静态类型检查器,严格遵守PEP 484标准,支持复杂的类型系统。
  • Pyright 是一款由微软开发的静态类型检查器,专为VS Code设计,支持实时反馈。
  • Type Checking in IDEs:现代IDE如PyCharm, Visual Studio Code通过插件形式无缝集成类型检查 ,提供即时反馈。

集成类型检查到开发流程中 ,如CI/CD管道 ,确保每次提交都经过类型验证,是持续提升代码健壮性的有效策略。例如,在GitHub Actions中加入Mypy检查:

name: CI
on: [push]

jobs:
  build:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v2
      - name: Set up Python
        uses: actions/setup-python@v2
        with:
          python-version: 3.11
      - name: Install dependencies
        run: |
          python -m pip install mypy
      - name: Run type checks
        run: mypy .

通过这些方法,类型提示和.pyi文件不仅能增强个人编码体验,也能显著提升团队协作效率和代码质量。

5、Python编译机制与.pyc、.pyo 🤖

5.1 Python解释器工作原理

Python是一种解释型语言,其代码在执行时被解释器逐行读取并翻译成机器码。这一过程分为两步:首先是编译(也称作解析),将源代码转换为字节码;其次是解释,字节码由虚拟机(Python虚拟机,PVM)执行。这一设计使得Python易于移植和调试。

5.2 .pyc文件生成与加载流程

当Python模块首次被导入时,解释器会将其编译成字节码并缓存为 .pyc 文件。这些文件位于模块的 __pycache__ 目录中,命名格式为 module.cpython-XY.pyc,其中XY代表Python版本标识。下次相同模块被导入时 ,如果源文件未修改,解释器直接加载 .pyc 文件,加快启动速度。例如:

# hello.py
print("Hello, Python!")

运行后,检查 __pycache__ 目录可见生成的 .pyc 文件。

5.3 .pyo文件优化编译的历史与弃用原因

.pyo 文件是Python早期版本中通过 -O 选项生成的优化编译文件,相比 .pyc 文件,会对字节码进一步优化,比如移除断言和 if __debug__: 语句。然而 ,从Python 3.8开始 ,.pyo 文件被弃用,主要原因是优化带来的收益有限,且维护成本高,特别是随着其他更高效优化手段的发展,如PyPy这样的JIT(Just-In-Time)编译器。

5.4 编译文件在部署中的应用与考虑

在生产部署Python应用时,考虑编译文件的使用策略很重要:

  • 性能:利用 .pyc 文件加速模块加载,尤其对于大型应用或频繁重启的服务。
  • 安全性:尽管 .pyc 文件提供了某种程度的代码混淆,但不应依赖其保护知识产权,因为源码仍可逆向工程恢复。
  • 维护:保持源码与部署环境的一致性,注意 .pyc 文件可能因不同Python版本或编译选项产生不兼容。
  • 更新管理:监控源代码变动,确保在修改后重新生成 .pyc 文件 ,避免旧版本字节码带来的问题。

综上所述 ,理解Python的编译机制及其产生的文件类型,有助于优化部署策略,提升应用性能和管理效率。

6、扩展你的Python:.pyd与跨平台考量 🌍

6.1 Windows下的C扩展编写

在Windows上,Python C扩展以 .pyd 文件形式存在 ,相当于动态链接库(DLL)。编写这类扩展需要使用Python C API。首先,设置Visual Studio环境,安装Python开发工具。一个简单的扩展例子如下:

#include <Python.h>

static PyObject* greet(PyObject* self, PyObject* args) {
    const char* name;
    if (!PyArg_ParseTuple(args, "s", &name)) {
        return NULL;
    }
    printf("Hello, %s!\n", name);
    Py_RETURN_NONE;
}

static PyMethodDef methods[] = {
    {"greet", greet, METH_VARARGS, "Prints a greeting."},
    {NULL, NULL, 0, NULL}
};

static struct PyModuleDef module = {
    PyModuleDef_HEAD_INIT,
    "example_extension",
    "A simple example extension.",
    -1,
    methods
};

PyMODINIT_FUNC PyInit_example_extension(void) {
    return PyModule_Create(&module);
}

编译后得到 example_extension.pyd,可在Python中使用:

import example_extension
example_extension.greet('World')

6.2 Linux/macOS上的.so文件对比

与Windows的 .pyd 相似,Linux和macOS上的Python C扩展以 .so(共享对象)形式存在。开发流程类似,但使用GCC或Clang编译器。构建过程可通过Python的 distutilssetuptools 自动化,例如 setup.py 文件:

from distutils.core import setup, Extension

module = Extension('example_extension',
                  sources=['example_extension.c'])

setup(name='Example Extension',
      version='1.0',
      description='A demo extension',
      ext_modules=[module])

执行 python setup.py build_ext --inplace 生成 .so 文件。

6.3 使用Cython加速Python

Cython允许用类似Python的语法编写代码 ,然后编译成C扩展,实现性能提升。首先安装Cython,然后编写 .pyx 文件:

# example_cy.pyx
def greet(name):
    print(f"Hello, {name}!")

设置 setup.py 使用Cython构建:

from setuptools import setup
from Cython.Build import cythonize

setup(
    ext_modules=cythonize("example_cy.pyx"),
)

构建后,使用 python setup.py build_ext --inplace 得到扩展模块。

6.4 跨平台编译与分发策略

跨平台编译Python扩展时,setuptools 配合 Cythoncffi 是不错的选择,它们能简化跨平台兼容性问题。对于分发 ,wheel 格式是推荐的方式,因为它预编译了二进制扩展,用户无需编译即可安装。使用 auditwheel(Linux)或 delocate(macOS)修复轮子(wheels)以便跨平台分发,确保包含所有依赖项。

综上所述,通过C扩展、Cython或其他工具,Python应用可以显著提升性能,同时跨平台分发策略确保了广泛兼容性和易用性。

7、总结与展望 🚀

探索Python编程的多面性,从基础的.py源代码到交互式的.ipynb笔记,再到高效的.pyi类型提示文件,本文深入解析了Python文件的类型与应用。了解.pyc字节码的编译机制,回顾.pyo优化文件的历史,同时探讨了.pyd扩展模块的编写与跨平台考量。文章还提供了实用的编码规范、版本控制策略和打包方法,是Python开发者提升代码质量和性能的宝典。
在这里插入图片描述
在这里插入图片描述

往期精彩文章

  1. 好家伙,Python自定义接口,玩得这么花

  2. 哎呀我去,Python多重继承还能这么玩?

  3. 太秀了!Python魔法方法__call__,你试过吗?

  4. Python函数重载6种实现方式,从此告别手写if-else!

  5. 嗷嗷,Python动态创建函数和类,是这么玩的啊

  6. Python混入类Mixin,远比你想象的更强大!

  7. Python -c原来还能这么用,学到了!

  8. Python模块导入,别out了,看看这些高级玩法!

  9. Python定时任务8种实现方式,你喜欢哪种!

  10. python文件:.py,.ipynb, pyi, pyc, pyd, pyo都是什么文件?

  11. Python也能"零延迟"通信吗?ZeroMQ带你开启高速模式!

  12. 掌握Python 这10个OOP技术,代码想写不好都难!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1802587.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【排序算法】总结篇

✨✨这些 排序算法都是指的 需要进行比较的排序算法 ✨✨下面都是略微讲解一下思路&#xff0c;如果需要详细了解哪一个排序&#xff0c;点击&#x1f449;链接即可 ✨✨对于时间、空间复杂度、稳定性&#xff0c;希望你&#x1f9d1;‍&#x1f393;能够理解记忆&#x1f9d1;…

MyBatisPlus插件生成代码

文章目录 概要安装插件使用插件 概要 MyBatis-Plus 是 MyBatis 的增强工具&#xff0c;旨在简化 MyBatis 的开发。MyBatis-Plus 代码生成器插件可以自动生成项目中常见的代码&#xff0c;如实体类、Mapper 接口、Service 接口和实现类、Controller 等&#xff0c;从而减少手动…

python代码中参数的默认值

python中的函数&#xff0c;可以给形参指定默认值。 带有默认值的参数&#xff0c;可以在调用的时候不传参。 如上图所示&#xff0c;在给函数设定形参的时候可以给函数形参设定默认值&#xff0c;当然默认参数的形参应该在非默认形参的后面。 如果在调用函数的时候&#xff…

SpringBoot整合SpringSecurit(二)通过token进行访问

在文章&#xff1a;SpringBoot整合SpringSecurit&#xff08;一&#xff09;实现ajax的登录、退出、权限校验-CSDN博客 里面&#xff0c;使用的session的方式进行保存用户信息的&#xff0c;这一篇文章就是使用token的方式。 在其上进行的改造&#xff0c;可以先看SpringBoot…

ctfshow-web入门-命令执行(web41_exp与分析)

过滤不严&#xff0c;命令执行 preg_match(/[0-9]|[a-z]|\^|\|\~|\$|\[|\]|\{|\}|\&|\-/i, $c) 过滤掉了数字、字母以及一些符号&#xff0c;之前接触过的无字母 rce 是取反编码再取反&#xff0c;采用不可见字符去绕过正则&#xff0c;但是这里取反符号被过滤掉了&#x…

还在为线上BUG苦苦找寻?试试IntelliJ IDEA远程调试线上Java程序

&#x1f604; 19年之后由于某些原因断更了三年&#xff0c;23年重新扬帆起航&#xff0c;推出更多优质博文&#xff0c;希望大家多多支持&#xff5e; &#x1f337; 古之立大事者&#xff0c;不惟有超世之才&#xff0c;亦必有坚忍不拔之志 &#x1f390; 个人CSND主页——Mi…

VMware导入小白分享的MacOS版本之后,无法开机的解决方案

前言 这段时间陆续有小伙伴找到小白&#xff0c;说&#xff1a;导入小白分享的MacOS版本之后&#xff0c;出现无法开机的问题。 遇到这个问题&#xff0c;并不是说明分享版本有问题&#xff0c;因为大部分小伙伴导入之后都没有出现类似的问题&#xff0c;都是导入之后开机&…

VBA经典应用69例应用5:使用VBA冻结窗格

《VBA经典应用69例》&#xff08;版权10178981&#xff09;&#xff0c;是我推出的第九套教程&#xff0c;教程是专门针对初级、中级学员在学习VBA过程中可能遇到的案例展开&#xff0c;这套教程案例众多&#xff0c;紧贴“实战”&#xff0c;并做“战术总结”&#xff0c;以便…

PaddleSpeech MFA:阿米娅中文音色复刻计划

PaddleSpeech&#xff1a;阿米娅中文音色复刻计划 本篇项目是对iterhui大佬项目[PaddleSpeech 原神] 音色克隆之胡桃的复刻&#xff0c;使用的PaddleSpeech的版本较新&#xff0c;也针对新版本的PaddleSpeech做了许多配置之上的更新并加入了自己对语音的对齐、配置、训练其它任…

Buildroot和Debian文件系统修改方法

本文档主要介绍在没有编译环境的情况下&#xff0c;如何修改buildroot和debian文件系统方法&#xff0c;如在buildroot文件系统中添加文件、修改目录等文件操作&#xff0c;在debian文件系统中&#xff0c;安装软件库、工具、扩大文件系统空间等等操作。 1.Debian文件系统 …

Java | Leetcode Java题解之第137题只出现一次的数字II

题目&#xff1a; 题解&#xff1a; class Solution {public int singleNumber(int[] nums) {int a 0, b 0;for (int num : nums) {b ~a & (b ^ num);a ~b & (a ^ num);}return b;} }

AndroidStudio无法识别连接夜神模拟器

方法一(无法从根本上解决) ①进入夜神模拟器安装路径下的bin路径(安装路径可以带有中文路径) ②打开cmd窗口,输入以下代码(一定要打开模拟器) nox_adb.exe connect 127.0.0.1:62001 方法二(根本上解决) 原因:Android Studio的adb版本与夜神模拟器的adb版本不一致 ①打开And…

【Unity】 HTFramework框架(五十一)代码片段执行器

更新日期&#xff1a;2024年6月8日。 Github源码&#xff1a;[点我获取源码] Gitee源码&#xff1a;[点我获取源码] 索引 Code Snippet Executer 代码片段执行器使用 Code Snippet Executer打开 Code Snippet Executer动态执行&#xff08;代码片段&#xff09;静态执行&#x…

core dump核心转储

检查核心转储是否开启&#xff0c;否则无法生成core文件 ulimit -a 如果为0就需要修改 ulimit -c 10240 写一个会触发core命令的程序 以浮点数运算为例 #include <iostream>int main() {int i 1/0; } 在编译时使用-g选项 运行程序&#xff0c;生成core文件 gdb调试 g…

本地部署GLM-4-9B清华智谱开源大模型方法和对话效果体验

GLM-4-9B是清华大学和智谱AI推出的最新一代预训练模型GLM-4系列中的开源版本。在语义、数学、推理、代码和知识等多方面的数据集测评中&#xff0c;GLM-4-9B及其人类偏好对齐的版本GLM-4-9B-Chat均表现出较高的性能&#xff0c;其通用能力评测结果甚至超越了Llama-3-8B开源大模…

如何解锁植物大战僵尸杂交版v2.0.88所有植物

如何解锁植物大战僵尸杂交版v2.0.88所有植物 前言安装相关软件快速解锁方法修改冒险模式修改挑战模式 前言 经过探索植物大战僵尸杂交版植物解锁和关卡有关&#xff0c;所以通过所有关卡就可以解锁所有植物。 安装相关软件 1.安装植物大战僵尸 2.安装Hex Editor Neo 快速解…

pytorch 加权CE_loss实现(语义分割中的类不平衡使用)

加权CE_loss和BCE_loss稍有不同 1.标签为long类型&#xff0c;BCE标签为float类型 2.当reduction为mean时计算每个像素点的损失的平均&#xff0c;BCE除以像素数得到平均值&#xff0c;CE除以像素对应的权重之和得到平均值。 参数配置torch.nn.CrossEntropyLoss(weightNone,…

【香橙派】Orange Pi AIpro体验——国产AI赋能

文章目录 &#x1f354;开箱&#x1f6f8;烧录镜像⭐启动系统&#x1f388;本机登录&#x1f388;远程登陆 &#x1f386;AI功能体验&#x1f50e;总结 &#x1f354;开箱 可以看到是很精美的开发组件 这里是香橙派官网 http://www.orangepi.cn/ 我们找到下面图片的内容&#…

uc/OS移植到stm32实现三个任务

文章目录 一、使用CubeMX创建工程二、uc/OS移植三、添加代码四、修改代码五、实践结果六、参考文章七、总结 实践内容 学习嵌入式实时操作系统&#xff08;RTOS&#xff09;,以uc/OS为例&#xff0c;将其移植到stm32F103上&#xff0c;构建至少3个任务&#xff08;task&#xf…

python有short类型吗

Python 数字数据类型用于存储数值。 Python 支持三种不同的数值类型&#xff1a;整型&#xff08;int&#xff09;、浮点型&#xff08;float&#xff09;、复数&#xff08;complex&#xff09;。 在其他的编程语言中&#xff0c;比如Java、C这一类的语言中还分有长整型&…