'How to execute Python Script that runs a excel instance and triggers VBA on daily basis in Azure
thanks for reading.
I need to run a Python Script in Azure on daily basis, but there are some challenges. The script uses following libraries and run the steps:
import os
import shutil
import win32com.client
from selenium import webdriver
- Python script navigates some URL to download 8 .xls files.
- Python script opens an Excel instance and triggers VBA code with win32com.
- VBA script loops all downloaded files and copies data into tabular form.
- VBA script saves CSV file of data.
- VBA script uploads CSV file to Azure Blob Storage.
- VBA script run SQL Server stored procedures and queries with uploaded CSV.
Process is fine and running smoothly. The challengue is to run it on daily basis without human interaction.
I read different approaches:
a) Use Windows VM in Azure and run with Windows Task Scheduler. I already did this and tomorrow morning will know if it works.
b) Use Docker and Azure services. Have not tried, but I've heard that it is more efficient.
I don't know which approach is more efficient in cost and runtime. I don't know if there is another solution.
The only thing I know, is that needs to have Excel installed to run VBA. Thankfull for any ideas.
Solution 1:[1]
You can use Containerized Azure Functions.
Docker container will give you the flexibility to install anything you want (like selenium, etc) and Azure Functions will enable you to have a time triggered execution (check this tutorial on official microsoft docs).
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|---|
| Solution 1 | Chayan Bansal |
