Skip to main content

Convert RVTools Excel exports into an Oracle Cloud (OCI) monthly cost estimate workbook.

Project description

Logo

Turn VMware RVTools exports into an Oracle Cloud monthly cost estimate


This utility ingests one or more RVTools vInfo sheets, pulls the latest Oracle Cloud Infrastructure prices, and generates an Excel file with per-VM and aggregate monthly costs for all included resources.

Because OCI pricing scales linearly, costs are calculated by summing per-VM OCPU, RAM and disk values — each rounded up to whole units. The output includes a per-VM breakdown alongside aggregate monthly and yearly totals.

Note: VMware and Oracle approach CPU allocation differently. VMware's hypervisor present physical cores and hyperthreads as logical processors for vCPU allocation to guest VMs. Oracle allocates a full physical core (1 OCPU) and lets the guest OS handle both hyperthreads itself. So 1 OCPU equals 2 vCPUs from the guest's perspective. Same physical compute, different abstraction layers. oci-rvtools divides vCPU counts by 2 and rounds up to convert between the two.


🚀 Features

  • Browser-based web app – no install required. Drop in your RVTools export on oci-rvtools.com and get the cost estimate instantly. Runs 100% browser-local via WebAssembly — nothing is uploaded, nothing leaves your device. Read Security & Privacy for more on this.
  • Direct RVTools ingestion – reads raw RVTools_export_all.xlsx files and ignores housekeeping VMs (vCLS-*).
  • Multi-file support – pass multiple files, a directory, or upload a .zip of exports in the web app to aggregate across sites.
  • Datacenter and Cluster filtering – list all Datacenters and Clusters in the input, then scope the estimate to a specific subset of these.
  • Configurable inclusion filters – toggle powered-off VMs for CPU/RAM and powered-off disks for storage calculations independently.
  • Automatic unit handling – converts MiB totals to GiB, rounds quantities up to whole units, and maps 2 vCPUs to 1 OCPU.
  • Live pricing lookup – fetches list prices for configurable OCI part numbers via the OCI pricing API.
  • Console logging – prints aggregation totals, pricing inputs, and powered-on/off inclusion choices to the console.
  • Polished Excel output – writes oci_cost_summary.xlsx with a Cost Summary sheet (Total Provisioned Disk and Used Disk sections) and a VM Details sheet with a per-VM cost breakdown. All quantities are Excel formulas — the Cost Summary totals are driven directly by the VM Details rows. Designed to look similar to the output from the official OCI Cost Estimator.

⚡ Quick start

Online (no install)

Visit oci-rvtools.com — drop in your RVTools .xlsx or a .zip of multiple exports, choose your options, and get the cost estimate. Everything runs in your browser via WebAssembly.

CLI

# Install from PyPI
pip install oci-rvtools

# Run the estimator
oci-rvtools \
  --rvtools ./customer/RVTools_export_all.xlsx \
  --output oci_cost_summary.xlsx

The tool contacts the OCI pricing API at runtime. Ensure the machine has outbound internet access.


🏗️ Installation options

PyPI, pipx or uv

# pip — installs into your active environment
pip install oci-rvtools

# pipx — isolated install, command available system-wide
pipx install oci-rvtools

# uv — one-off run without a permanent install
uvx oci-rvtools --rvtools ./customer/RVTools_export_all.xlsx

Homebrew (macOS)

brew tap KimTholstorf/oci-rvtools-cost-estimator
brew install oci-rvtools

Docker

# CLI mode — mount your working directory to /data
docker run --rm \
  -v "$(pwd)":/data \
  ghcr.io/kimtholstorf/oci-rvtools-cost-estimator:latest \
  --rvtools /data/RVTools_export_all.xlsx \
  --output /data/oci_cost_summary.xlsx

# Web app mode — no arguments starts the local web UI on port 8080
docker run --rm -p 8080:8080 \
  ghcr.io/kimtholstorf/oci-rvtools-cost-estimator:latest
# then open http://localhost:8080

From source

git clone https://github.com/KimTholstorf/oci-rvtools-cost-estimator.git
cd oci-rvtools-cost-estimator
python3 -m venv .venv
source .venv/bin/activate
pip install .

# Run the CLI
oci-rvtools --rvtools ./customer/RVTools_export_all.xlsx

# Or serve the web UI locally
python3 -m http.server 8080 --directory docs/
# then open http://localhost:8080

📥 Input expectations

  • RVTools workbook(s) in .xlsx format containing the vInfo sheet (default RVTools_export_all.xlsx).
  • All calculations default to powered-on VMs, but powered-off VM CPU/RAM and disk capacity can be included via flags.

📤 Output workbook

The generated Excel file (oci_cost_summary.xlsx by default) contains two sheets:

  1. Cost Summary – Aggregate monthly costs with two sections: Total Provisioned Disk and Used Disk. Includes a banner row, metadata block (source files, filters, hours, currency, VPU value, powered-on/off flags), pricing table with full Excel formulas, and advisory text. Part quantities are driven by SUM formulas referencing the VM Details sheet.

  2. VM Details – One row per VM with OCPU, RAM and disk values alongside monthly and yearly cost formulas. Editing a value here automatically updates the Cost Summary totals.

Per-VM quantities are rounded up to whole units. Block Volume Performance Units (VPU) scale with disk capacity (VPU per GB × GB).


🛠️ CLI reference

Argument Description
--version Print the script version and exit.
--rvtools PATH [PATH ...] One or more RVTools .xlsx files or directories to scan. Required.
--output FILE Destination workbook path. Defaults to oci_cost_summary.xlsx.
--hours HOURS Hours per month to bill. Defaults to 730.
--currency CODE Pricing currency (passed to OCI pricing API). Defaults to USD.
--ocpu-part PART OCI part number for OCPU per hour (default B97384, i.e. VM.Standard.E5.Flex).
--memory-part PART OCI part number for memory GB per hour (default B97385, i.e. VM.Standard.E5.Flex).
--storage-part PART OCI part number for block storage capacity per month (default B91961).
--vpu-part PART OCI part number for block volume performance units (default B91962).
--vpu VALUE VPUs per GB (range 1–120, default 10, i.e Balanced performance level).
--include-poweredoff-vms Include powered-off VMs when summing vCPU and RAM.
--include-poweredoff-disks Include powered-off VMs when summing disk usage (default).
--exclude-poweredoff-disks Ignore powered-off VMs when summing disk usage.
--list Print all Datacenter and Cluster names found in the input file(s) and exit.
--datacenter NAME [NAME ...] Only include VMs in the given Datacenter(s). Quote names with spaces e.g. "DC East".
--cluster NAME [NAME ...] Only include VMs in the given Cluster(s). Quote names with spaces e.g. "Production-01".

Paths can point to folders and the script recursively picks up .xlsx files.

When both --datacenter and --cluster are specified, a VM must match both conditions (AND logic). Multiple values within each flag are matched with OR logic.


📈 Examples

# Baseline run (powered-on VMs only, powered-off disks included)
oci-rvtools \
  --rvtools ./customer/RVTools_export_all.xlsx

# List Datacenter and Clusters in input file
oci-rvtools \
  --rvtools ./customer/RVTools_export_all.xlsx \
  --list
  
# Use Datecenter and Cluster filtering
oci-rvtools \
  --rvtools ./customer/RVTools_export_all.xlsx \
  --datacenter DC-NAME --cluster CLUSTER-NAME
  
# Aggregate multiple exports and change output name
oci-rvtools \
  --rvtools ./customer/site-a.xlsx ./customer/site-b.xlsx \
  --output reports/oci_cost_summary.xlsx

# Include powered-off VM CPU/RAM
oci-rvtools \
  --rvtools ./customer/RVTools_export_all.xlsx \
  --include-poweredoff-vms \

# Override pricing part numbers (VM.Standard.E6.Flex) and hours per month
oci-rvtools \
  --rvtools ./customer/RVTools_export_all.xlsx \
  --hours 744 \
  --ocpu-part B111129 \
  --memory-part B111130

# Use VM.Standard.E6.Ax.Flex shape
oci-rvtools \
  --rvtools ./customer/RVTools_export_all.xlsx \
  --ocpu-part B112530 \
  --memory-part B112531

# Ultra High Performance for Storage
oci-rvtools \
  --rvtools ./customer/RVTools_export_all.xlsx \
  --vpu 30   # Ultra High Performance is VPU 30-120.

🍿 Demo

CLI

asciinema

Web-UI

asciinema


⚠️ Notes

  • The CLI relies on real-time pricing data, so expect run failures if the Oracle pricing API is unreachable or if your machine is not connected to the internet.
  • Generated Excel workbooks contain formulas and formatting. Excel recalculates automatically when opened.

Happy estimating! Contributions and pull requests are welcome.


MIT License — © 2026 Kim Tholstorf

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

oci_rvtools-1.2.0.tar.gz (25.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

oci_rvtools-1.2.0-py3-none-any.whl (22.5 kB view details)

Uploaded Python 3

File details

Details for the file oci_rvtools-1.2.0.tar.gz.

File metadata

  • Download URL: oci_rvtools-1.2.0.tar.gz
  • Upload date:
  • Size: 25.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for oci_rvtools-1.2.0.tar.gz
Algorithm Hash digest
SHA256 6ddc3c7e87de1c8e60b488d5289af34a86d301e2c9fc256dd63304860167d5da
MD5 1c439ac3f7b94443027cad967d71e822
BLAKE2b-256 136047dfffe63c9f6a810e32993ab4fca934976098e3c6b74e3c604a30ad7d4f

See more details on using hashes here.

Provenance

The following attestation bundles were made for oci_rvtools-1.2.0.tar.gz:

Publisher: pypi-publish.yml on KimTholstorf/oci-rvtools-cost-estimator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file oci_rvtools-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: oci_rvtools-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 22.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for oci_rvtools-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 293328f5bb9c874ab71469273cc4377c1700c0d95e304cd1d0357d5941b5df02
MD5 4c62534a08d689aabe8521ac2f0a5920
BLAKE2b-256 c4c3cf098c105441a9b517a44d35e1c3cbf367bdf233c89cedb58b8b27925158

See more details on using hashes here.

Provenance

The following attestation bundles were made for oci_rvtools-1.2.0-py3-none-any.whl:

Publisher: pypi-publish.yml on KimTholstorf/oci-rvtools-cost-estimator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page