CsvScriptModel
CSV Script Models are a type of model that executes a command with a given set of args. This command needs to return a well formatted with a header row to stdout.
Visivo will be able to access the generate file as a model by storing a duckdb file in the source directory.
Example
Echoing all of your data is probably not a very practical example, but it does nicely demonstrate how the feature works!
models:
- name: csv
table_name: csv
args:
- echo
- |
x,y
1,9
2,1
3,2
4,3
5,5
6,8
In this example we'll use python to generate a csv of processes running on your machine and make that csv available to Visivo as a model for analysis.
import subprocess
import csv
import sys
# Define the CSV file to write
csv_file = "data/processes.csv"
# Execute the 'ps aux' command
result = subprocess.run(["ps", "aux"], stdout=subprocess.PIPE, text=True)
# Split the output into lines
lines = result.stdout.strip().split("/n")
# Write CSV to stdout
writer = csv.writer(sys.stdout)
writer.writerow(
["USER","PID","%CPU","%MEM","VSZ","RSS","TTY","STAT","START","TIME","COMMAND"]
) # Header
for line in lines[1:]: # Skip the header line from the ps output
row = line.split(None, 10) # Split on whitespace, but only for the first 10 columns
writer.writerow(row)
python create_processes_csv.py
into the args list format in a model.
models:
- name: processes
table_name: processes
args:
- python
- create_processes_csv.py
One of the best use cases for this type of model is to store a static csv in your project and cat it into a model. This great because it's simple and allows you to version control your csv data.
columns,go,up,here
1,text,more text,6
2,stuff,more stuff,7
cat
the csv file in a model.
models:
- name: file_model
table_name: file_model
args:
- cat
- file.csv
The args are python subprocess list args and you can read their source documentation here.
Attributes
Field | Type | Default | Description |
---|---|---|---|
path | string | None | A unique path to this object |
name | string | None | The unique name of the object across the entire project. |
table_name | string | model | The name to give the resulting models table |
args | array | None | An array of the variables that build your command to run. |