- xlwings Newsletter
- Posts
- The "new" xlwings Server (self-hosted)
The "new" xlwings Server (self-hosted)
Hi all,
It’s been a while since the last newsletter, which usually means that I’ve been busy. This time I was busy with bringing xlwings Server (self-hosted) to a “minimally stable” version.
Yes, xlwings Server has been “a thing” for a while now, but up until now, it was a do-it-yourself exercise, with users having to write the complete backend on their own. This has obviously proven to be a challenge for many, as not everybody is a web developer.
The “new” xlwings Server is an out-of-the-box product with everything on board, including custom functions, scripts, and tools for task pane development with the modern Office.js add-ins (no JavaScript required). It also makes complex topics like authentication incl. SSO easy to implement.
xlwings Server finally has a dedicated documentation:
From the docs, here a high-level introduction to xlwings Server:
xlwings Server adds Python support to Microsoft Excel and Google Sheets without the need of a local Python installation. xlwings Server is self-hosted and runs on any platform that supports Python or Docker, including bare-metal servers, Linux-based VMs, Docker Compose, Kubernetes, and serverless products like Azure functions or AWS Lambda. Here are a few highlights:
Compatible with Python 3.9+
Compatible with all Excel platforms, including Excel on Windows and macOS, and Excel on the web
Compatible with all Python packages, including custom ones and those from private registries
Supports custom scripts and custom functions including streaming functions and object handles
Allows you to develop modern Office.js add-ins by writing Python code instead of JavaScript
In addition to Office.js add-ins, you can also use VBA, Office Scripts, and Google Apps Script to talk from Excel to your server. These, however, don’t support custom functions.
Runs in air-gapped environments without Internet access or connection to any Microsoft servers
Intellectual property protection: the Python source code can’t be accessed by the Excel user.
Supports SSO (single sign-on) authentication and RBAC (role-based access control) via Microsoft Entra ID (previously known as Azure AD)
No sensitive credentials need to be stored on the end-user’s computer or in the workbook
No dependency on Node.js or Webpack even when using Office.js add-ins
Built with FastAPI, a high-performance, async web framework
Comes optionally with htmx (client-server interaction), Alpine.js (for client interactions), Socket.io (for streaming functions), and Bootstrap-xlwings (Bootstrap theme in the Excel look)
Full source code is on GitHub allowing for complete customization
xlwings Server is free for non-commercial use—commercial use requires a paid plan
Cheers,
Felix