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