
PyScript 无法直接访问本地文件系统,但可通过配置 py-config 的 files 键,将网络可访问的文件预加载至其内置虚拟文件系统,从而在 Python 代码中使用 open() 等标准 I/O 函数正常读取。
pyscript 无法直接访问本地文件系统,但可通过配置 `py-config` 的 `files` 键,将网络可访问的文件预加载至其内置虚拟文件系统,从而在 python 代码中使用 `open()` 等标准 i/o 函数正常读取。
在 PyScript 环境中,浏览器沙箱机制严格限制了对本地文件系统的直接访问(如 open("data.txt") 会触发 FileNotFoundError),这是出于安全考虑的强制约束。但实际开发中,常需加载配置、CSV、JSON 或文本数据等资源。PyScript 提供了安全、声明式的解决方案:通过
✅ 正确做法:使用 files 配置加载文件
确保目标文件可通过 HTTP 访问(例如部署在 GitHub Pages、Vercel,或本地启动简易服务器):
# 在项目根目录启动 Python 内置服务器(端口 8000) python3 -m http.server 8000
此时,./data/config.json 可通过 http://localhost:8000/data/config.json 访问。
在 HTML 中配置 py-config:
<py-config>
{
"packages": ["pandas"],
"files": [
"/data/config.json",
"/assets/sample.csv"
]
}
</py-config>? 注意:路径为相对于当前页面 URL 的完整路径(支持绝对路径 /data/... 或相对路径 data/...),PyScript 会自动发起 fetch 请求并将其写入 VFS 的对应路径。
随后,在
# 成功读取 —— 文件已存在于虚拟文件系统中
with open("/data/config.json", "r") as f:
config = json.load(f)
print("Loaded config:", config)
import pandas as pd
df = pd.read_csv("/assets/sample.csv")
print(df.head())⚠️ 重要注意事项
- 文件必须可跨域访问:若文件托管在第三方服务,请确保响应头包含 Access-Control-Allow-Origin: *(或明确允许你的域名),否则浏览器会因 CORS 拒绝请求。
- 路径大小写敏感:VFS 路径与 files 列表中声明的路径必须完全一致(包括大小写和斜杠方向)。
- 不支持动态上传或写入:files 仅支持只读预加载;运行时无法创建新文件或修改已加载文件(VFS 是只读挂载)。
- 避免使用已废弃的 [[fetch]]:旧版文档中的 [[fetch]] 配置逻辑复杂、易出错,官方已明确推荐统一使用更简洁可靠的 files 数组。
✅ 总结
只要将文件托管在 Web 可达位置,并在










