MCP Server for reading and writing .xls Excel files (Excel 97-2003 binary format)
Project description
MCP XLS Server
支持读取和写入 .xls 格式(Excel 97-2003 二进制格式)的 MCP 服务器。
功能特性
- ✅ 读取
.xls文件数据 - ✅ 写入数据到
.xls文件 - ✅ 创建新的
.xls文件 - ✅ 更新指定单元格的值
- ✅ 列出文件中的所有工作表
- ✅ 获取文件元数据信息
安装
从 PyPI 安装(推荐)
pip install xls-mcp-servers
使用 uvx 运行(无需安装)
uvx xls-mcp-servers
从源码安装
- 克隆仓库:
git clone https://github.com/Lincygbh/xls-mcp-server.git
cd xls-mcp-server
- 安装依赖:
pip install -r requirements.txt
配置 MCP 客户端
Cursor 配置
在 Cursor 的 MCP 配置文件中添加:
{
"mcpServers": {
"xls-mcp-servers": {
"command": "xls-mcp-servers"
}
}
}
或者如果从源码运行:
{
"mcpServers": {
"xls-mcp-servers": {
"command": "python",
"args": ["/path/to/xls-mcp-servers/server.py"],
"cwd": "/path/to/xls-mcp-servers"
}
}
}
注意:
- 如果使用
pip install安装,路径应为 Python 包安装位置 - 如果使用
uvx运行,无需配置路径,直接使用包名即可 - 如果从源码运行,请将路径
/path/to/xls-mcp-servers替换为你的实际路径(Windows 用户使用C:/path/to/xls-mcp-servers格式)
路径配置
如果需要限制服务器可以访问的文件路径,可以在 server.py 中修改 ALLOWED_PATHS 列表:
ALLOWED_PATHS = [
"/path/to/data", # Linux/Mac 示例
"C:/path/to/data" # Windows 示例
]
如果 ALLOWED_PATHS 为空列表,则允许访问所有路径。
可用工具
1. read_xls - 读取 Excel 文件
读取 .xls 文件的数据。
参数:
filepath(必需): Excel 文件路径sheet_name(可选): 工作表名称,默认读取第一个工作表start_row(可选): 起始行号(0-based)end_row(可选): 结束行号(0-based)start_col(可选): 起始列号(0-based)end_col(可选): 结束列号(0-based)
示例:
{
"filepath": "/path/to/example.xls",
"sheet_name": "Sheet1",
"start_row": 0,
"end_row": 10
}
2. write_xls - 写入数据到 Excel 文件
写入数据到 .xls 文件。
参数:
filepath(必需): Excel 文件路径sheet_name(必需): 工作表名称data(必需): 二维数组数据start_cell(可选): 起始单元格(如 "A1"),默认为 "A1"overwrite(可选): 是否覆盖现有文件,默认为 false(追加模式)
示例:
{
"filepath": "/path/to/test.xls",
"sheet_name": "Sheet1",
"data": [
["ID", "PATH", "NAME"],
[1001, "A/B", "张三"]
],
"start_cell": "A1"
}
3. list_sheets_xls - 列出工作表
列出 .xls 文件中的所有工作表名称。
参数:
filepath(必需): Excel 文件路径
示例:
{
"filepath": "/path/to/example.xls"
}
4. create_xls - 创建新的 Excel 文件
创建新的 .xls 文件。
参数:
filepath(必需): 要创建的文件路径sheet_name(可选): 工作表名称,默认为 "Sheet1"data(可选): 初始数据(二维数组)
示例:
{
"filepath": "/path/to/new_file.xls",
"sheet_name": "Sheet1",
"data": [
["列1", "列2", "列3"],
["值1", "值2", "值3"]
]
}
5. get_xls_metadata - 获取文件元数据
获取 .xls 文件的元数据信息。
参数:
filepath(必需): Excel 文件路径
示例:
{
"filepath": "/path/to/example.xls"
}
6. update_xls_cell - 更新单元格
更新 .xls 文件中指定单元格的值。
参数:
filepath(必需): Excel 文件路径sheet_name(必需): 工作表名称cell(必需): 单元格地址(如 "A1")value(必需): 要设置的值
示例:
{
"filepath": "/path/to/test.xls",
"sheet_name": "Sheet1",
"cell": "A1",
"value": "新值"
}
使用示例
读取 NPC 配置表
# 通过 MCP 调用
read_xls(
filepath="/path/to/config.xls",
sheet_name="Sheet1"
)
创建新的配置
# 通过 MCP 调用
write_xls(
filepath="/path/to/config.xls",
sheet_name="Sheet1",
data=[
[1001, "示例数据1", "示例数据2", 331, 331, "示例名称", 0, 15, 0]
],
start_cell="A2" # 从第2行开始写入(第1行可能是表头)
)
技术说明
使用的库
- xlrd: 用于读取
.xls文件 - xlwt: 用于写入
.xls文件 - xlutils: 用于复制和修改现有的
.xls文件 - mcp: MCP SDK,用于实现 MCP 协议
限制
- 只支持
.xls格式:不支持.xlsx格式(需要使用其他 MCP 服务器) - 日期处理:日期会被转换为字符串格式(YYYY-MM-DD)
- 格式保留:使用
xlutils.copy时,会尽量保留原有格式,但某些复杂格式可能无法完全保留
故障排除
1. 文件路径错误
确保使用绝对路径,并且路径中的反斜杠需要转义或使用正斜杠。
2. 权限错误
确保对目标目录有读写权限。
3. 文件被占用
如果文件正在被 Excel 或其他程序打开,写入操作会失败。请先关闭文件。
4. 工作表不存在
使用 list_sheets_xls 先查看文件中有哪些工作表。
更新日志
- 2026-01-22: 初始版本,支持基本的读写功能
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file xls_mcp_servers-1.0.0.tar.gz.
File metadata
- Download URL: xls_mcp_servers-1.0.0.tar.gz
- Upload date:
- Size: 9.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7e3aed314500ca66aff612905bded2ed01283e61b4e06c9382ecc9267762b4a3
|
|
| MD5 |
89d23e87d99300bfcaf9a6832ace0567
|
|
| BLAKE2b-256 |
deae65ef9e37810f7162f3e602efee9dca0c157e213a5a4eb78b08b3ee5b2ea8
|
File details
Details for the file xls_mcp_servers-1.0.0-py3-none-any.whl.
File metadata
- Download URL: xls_mcp_servers-1.0.0-py3-none-any.whl
- Upload date:
- Size: 7.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7fd88a05797ab6f43ef7e7ffce4e822d3b60885c58bdd281b3bec7284758eaac
|
|
| MD5 |
ce5d1177c00b6c45b43c41946ec303a6
|
|
| BLAKE2b-256 |
f146e561aa67c6fb4f7bc65c05a6bf0dd8389fc15b5dca132e4935083742712b
|