An UNOFFICIAL Python API for the NanoVNA series of vector network analyzers
Project description
nvnapython
An Unofficial Python API for the NanoVNA Device Series
A non-GUI Python API for the NanoVNA series of vector network analyzer devices. This library provides programmatic control over NanoVNA devices for automated S-parameter measurements, data collection, and analysis.
This repository uses official resources and documentation but is NOT endorsed by any official NanoVNA product, owner, or company. Refer to official resources and support for product information. This library is developed and tested against the NanoVNA-F V2 and NanoVNA-F V3; other models are supported by selecting their envelope, but knock-off or custom devices may not be compatible and have not been tested.
Features
- Device Discovery — automatic detection and serial connection to NanoVNA devices
- Frequency Sweeps — collect S11 / S21 sweep data across specified frequency ranges
- Per-Model Envelopes — sweep-point, frequency, and slot bounds for the F V2, F V3, H4, and a generic fallback
- Screen Capture — read the device framebuffer and decode it to an image
- Calibration — drive an interactive SOLT (Short-Open-Load-Thru) calibration
- Data Export — easy integration with
matplotlibandnumpy - Error Handling — input checking against the selected model and verbose output options
- Device Control — full programmatic control of NanoVNA settings and measurements
Installation
pip install nvnapython
The library itself depends only on pyserial. The plotting and screen-capture examples need an optional extra:
pip install "nvnapython[plotting]"
Python 3.10+ is required.
Quick Start
from nvnapython import nanoVNA
nvna = nanoVNA()
found, connected = nvna.autoconnect()
if connected:
print(nvna.info())
nvna.disconnect()
To collect an S11 sweep:
from nvnapython import nanoVNA
nvna = nanoVNA()
found, connected = nvna.autoconnect()
if connected:
nvna.pause()
s11 = nvna.get_scan_s11(int(1e9), int(3e9), 200) # 1-3 GHz, 200 points
nvna.resume()
nvna.disconnect()
print(s11)
Selecting a Device Model
A fresh nanoVNA() is seeded with the NanoVNA-F V2 envelope. If you have a different model, select its envelope so the library's range checks match your hardware:
nvna.select_existing_device("NANOVNA_F_V3") # 50 kHz - 6 GHz, up to 801 points
print(nvna.list_known_models()) # F V2, F V3, H4, GENERIC
Examples
The main GitHub repository provides runnable examples, grouped by what they demonstrate.
Getting started / device control
hello_world.py— connect, read device info, disconnectusing_autoconnect.py— detect and connect to a NanoVNA by USB IDidentify_and_select_model.py— read the device identity and select the matching model envelopeusing_command_func.py— send raw device commands for functionality not yet wrapped by the library
Acquisition
basic_scan.py— run a single S11 sweep over a frequency rangetwo_port_s21.py— collect S21 (transmission) datarobust_acquisition_loop.py— a resilient repeated-acquisition loop
Plotting scan data
plotting_scan.py— plot a single sweep (magnitude, phase, and a Smith-style complex plot)plotting_waterfall_static.py— collect several sweeps and render a static waterfall plotplotting_waterfall_realtime.py— a live, continuously updating waterfall plot
Calibration
solt_calibration.py— interactively run a SOLT (Short-Open-Load-Thru) calibration
Screen capture
screen_capture.py— read the device framebuffer and save it as an image
Exporting data
save_raw_to_csv.py— run a scan and write frequency/real/imaginary to a CSV filesave_scan_csv.py— as above, with derived magnitude (dB) and phase (deg) columns
Most plotting and capture examples require the optional plotting dependencies:
pip install "nvnapython[plotting]"
Documentation
For comprehensive documentation, the full command reference, advanced examples, and troubleshooting:
- Library GitHub repository: https://github.com/LC-Linkous/nanoVNA_python/
- Official NanoVNA documentation: https://nanovna.com/ (not associated with this library)
Contributing
This is an unofficial community project. Contributions welcome!
- Report bugs and request features on GitHub
- For device information and OFFICIAL resources, see https://nanovna.com/
- Please do NOT request features or report bugs to the official NanoVNA community or makers! This is an unofficial project and they do not maintain it.
Citing
If you use this library in your work, citation details are in the repository's CITATION.cff.
License
GPL-2.0 — this package and the repo code is unofficial software with no warranty, offered AS-IS. Use at your own risk.
The licensing of this software does NOT take priority over the official releases and the decisions of the official NanoVNA team or device makers. This licensing does NOT take priority for any of their products, including the devices that can be used with this software.
Acknowledgments
- The NanoVNA device creators and community, who have created an awesome line of devices
- Official NanoVNA documentation and resources, especially nanovna.com
- All contributors to this library, including those who have contributed code and reached out with questions
Disclaimer: This software is unofficial and not supported by the NanoVNA team or device makers. For official software and support, visit nanovna.com. The NanoVNA makers do not offer tech support for this software, do not maintain it, and have no responsibility for any of the contents.
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 nvnapython-2.0.0.tar.gz.
File metadata
- Download URL: nvnapython-2.0.0.tar.gz
- Upload date:
- Size: 32.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e947a057f0c3b6d25e903a4c3e1c28875b813f4c4aeedfb083a1d4d25fc943ec
|
|
| MD5 |
017ed6b83c942f854d61d6675217ede9
|
|
| BLAKE2b-256 |
9eebba069d1c26875bfb2f9e7f874a08bb3a3134fecd5ea8e744b7e7c7235d69
|
Provenance
The following attestation bundles were made for nvnapython-2.0.0.tar.gz:
Publisher:
release.yml on LC-Linkous/nanoVNA_python
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
nvnapython-2.0.0.tar.gz -
Subject digest:
e947a057f0c3b6d25e903a4c3e1c28875b813f4c4aeedfb083a1d4d25fc943ec - Sigstore transparency entry: 1812119821
- Sigstore integration time:
-
Permalink:
LC-Linkous/nanoVNA_python@ce095dc1e935fe0c86e1a7a0c086cb2b4ead7584 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/LC-Linkous
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@ce095dc1e935fe0c86e1a7a0c086cb2b4ead7584 -
Trigger Event:
workflow_dispatch
-
Statement type:
File details
Details for the file nvnapython-2.0.0-py3-none-any.whl.
File metadata
- Download URL: nvnapython-2.0.0-py3-none-any.whl
- Upload date:
- Size: 39.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
86b44e1dbe662c01d753280ff7cb14b59ae7c328444f34dd6d01cc8ffb5ce0d7
|
|
| MD5 |
92ccfca535603e594a82128447679635
|
|
| BLAKE2b-256 |
f33a3f73aa9f95f5d2a721e5e4bcf7d325a6d9f7dfe675bfc378d924f9319d72
|
Provenance
The following attestation bundles were made for nvnapython-2.0.0-py3-none-any.whl:
Publisher:
release.yml on LC-Linkous/nanoVNA_python
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
nvnapython-2.0.0-py3-none-any.whl -
Subject digest:
86b44e1dbe662c01d753280ff7cb14b59ae7c328444f34dd6d01cc8ffb5ce0d7 - Sigstore transparency entry: 1812119835
- Sigstore integration time:
-
Permalink:
LC-Linkous/nanoVNA_python@ce095dc1e935fe0c86e1a7a0c086cb2b4ead7584 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/LC-Linkous
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@ce095dc1e935fe0c86e1a7a0c086cb2b4ead7584 -
Trigger Event:
workflow_dispatch
-
Statement type: