Jupyter Notebook 中显示图片、音频、视频的方法汇总

在 Jupyter Notebook 中显示图片、音频、视频的方法有多种,以下是按类别汇总的常用方法,涵盖直接调用、库函数处理等场景,附代码示例和说明:

一、显示图片

1. 基于 IPython.display.Image(最直接,支持本地文件/URL)

适用于快速显示本地图片文件或网络图片,无需复杂处理。

python 复制代码
from IPython.display import Image

# 显示本地图片(路径为相对路径或绝对路径)
Image(filename="test_image.png", width=300, height=200)

# 显示网络图片(直接传入URL)
Image(url="https://example.com/image.jpg", width=400)
2. 基于 matplotlib(支持图像数组/处理后显示)

适用于从数组(如OpenCV读取的图像)或处理后的图像数据中显示,需结合 matplotlib.pyplot

python 复制代码
import matplotlib.pyplot as plt
import cv2  # 需安装:pip install opencv-python
import numpy as np

# 方法1:显示本地图片(通过matplotlib读取)
img = plt.imread("test_image.png")  # 读取图片为数组(RGB格式)
plt.figure(figsize=(8, 6))  # 设置画布大小
plt.imshow(img)  # 显示图片
plt.axis("off")  # 隐藏坐标轴
plt.show()

# 方法2:显示OpenCV读取的图片(注意OpenCV默认BGR格式,需转RGB)
img_cv = cv2.imread("test_image.png")  # 读取为BGR格式
img_rgb = cv2.cvtColor(img_cv, cv2.COLOR_BGR2RGB)  # 转换为RGB
plt.imshow(img_rgb)
plt.axis("off")
plt.show()
3. 基于 PIL(Pillow,支持图像处理后显示)

适用于用Pillow库处理图片(如裁剪、缩放)后直接显示。

python 复制代码
from PIL import Image as PILImage
import matplotlib.pyplot as plt

# 用Pillow打开图片并处理
img = PILImage.open("test_image.png")
img_resized = img.resize((300, 200))  # 缩放

# 显示处理后的图片
plt.imshow(img_resized)
plt.axis("off")
plt.show()
4. 基于 Markdown 语法(静态嵌入,无需代码)

直接在 Notebook 的 Markdown 单元格中用 Markdown 语法插入图片,适合固定路径的图片。

markdown 复制代码
# 插入本地图片
![图片描述](test_image.png)

# 插入网络图片
![图片描述](https://example.com/image.jpg)

二、播放音频

1. 基于 IPython.display.Audio(支持本地文件/音频数组)

适用于播放本地音频文件(如wav、mp3)或从数组生成的音频数据。

python 复制代码
from IPython.display import Audio
import numpy as np

# 方法1:播放本地音频文件
Audio(filename="test_audio.wav")  # 支持wav、mp3等格式

# 方法2:播放音频数组(如生成正弦波)
sample_rate = 44100  # 采样率
duration = 2  # 时长2秒
frequency = 440  # 频率440Hz(A音)
t = np.linspace(0, duration, int(sample_rate * duration), endpoint=False)
audio_data = np.sin(2 * np.pi * frequency * t)  # 生成正弦波数据
Audio(audio_data, rate=sample_rate)  # 播放数组音频

三、播放视频

1. 基于 IPython.display.Video(支持本地文件/URL)

适用于直接播放本地视频文件或网络视频,支持常见格式(如mp4、mov)。

python 复制代码
from IPython.display import Video

# 播放本地视频(路径为相对/绝对路径)
Video("output_video.mp4", width=600, height=400, embed=True)  # embed=True确保嵌入播放

# 播放网络视频(传入URL)
Video(url="https://example.com/video.mp4", width=800)
2. 基于 HTML 嵌入(支持在线视频/自定义播放器)

适用于嵌入在线视频(如YouTube、B站)或自定义视频标签,需用 IPython.display.HTML

python 复制代码
from IPython.display import HTML

# 嵌入YouTube视频(替换视频ID)
youtube_video_id = "abc123"
HTML(f"""
<iframe width="600" height="400" 
src="https://www.youtube.com/embed/{youtube_video_id}" 
frameborder="0" allowfullscreen></iframe>
""")

# 嵌入本地视频(通过HTML5 video标签,更灵活)
HTML("""
<video width="600" height="400" controls>
  <source src="output_video.mp4" type="video/mp4">
  您的浏览器不支持视频播放
</video>
""")

注意事项:

  1. 路径问题:本地文件需确保路径正确(相对路径相对于Notebook文件位置,绝对路径需完整)。
  2. 格式支持:不同浏览器/Notebook环境对音视频格式支持可能不同(mp4、wav通常兼容)。
  3. 数据大小:过大的媒体文件可能导致Notebook加载缓慢,建议压缩后使用。

根据需求选择对应的方法即可,简单显示优先用 IPython.display 中的类,处理数据(如数组)优先用 matplotlib 或音频/视频处理库。

相关推荐
HIT_Weston1 分钟前
85、【Agent】【OpenCode】bash 工具提示词(HEREDOC)
人工智能·agent·opencode
AI技术控4 分钟前
Transformer 的 Encoder 和 Decoder 模块介绍:从结构原理到大模型应用实践
人工智能·python·深度学习·自然语言处理·transformer
Codebee4 分钟前
日抛型软件的双链路设计——从"日抛"到"认知进化"的范式革命
人工智能
KaMeidebaby12 分钟前
卡梅德生物技术快报|单克隆抗体人源化 PEG 修饰质控方法体系构建与验证
服务器·前端·数据库·人工智能·算法·百度·新浪微博
LaughingZhu12 分钟前
Product Hunt 每日热榜 | 2026-05-16
人工智能·经验分享·深度学习·神经网络·产品运营
wuxinyan12313 分钟前
工业级大模型学习之路015:RAG零基础入门教程(第十一篇):系统重构与代码规范化
人工智能·python·学习·重构·rag
灵机一物18 分钟前
灵机一物AI原生电商小程序、PC端(已上线)-【技术深度解析】Bun 6 天 AI 重写 96 万行代码:从 Zig 迁移 Rust 全流程与行业影响
开发语言·人工智能·rust
wuxinyan12318 分钟前
工业级大模型学习之路014:RAG零基础入门教程(第十篇):系统性能与资源优化
人工智能·学习·rag
STLearner20 分钟前
CVPR 2026 | 时空时序论文总结(天气预报,交通模拟,域自适应等)
论文阅读·人工智能·深度学习·神经网络·机器学习·计算机视觉·数据挖掘