Query CSV data sources
Use csv.from()
and
experimental csv.from()
to query CSV data with Flux.
Query a CSV string, CSV file, or CSV data from a URL.
Import the csv
or experimental/csv
package.
CSV parsing modes
csv.from()
supports two CSV parsing modes:
- annotations: (Default) Use CSV annotations to determine column data types and table grouping.
- raw: Parse all columns as strings and use the first row as the header row and all subsequent rows as data.
When using the annotations parsing mode, CSV data must include all annotation rows
(#datatype
, #group
, and #default
).
Results structure
The structure of results returned by csv.from()
depends on the
parsing mode used.
- annotations:
csv.from()
returns a stream of tables grouped by columns defined astrue
in the#group
annotation row. - raw:
csv.from()
returns a stream of tables with no grouping (all rows are in a single table). All data is formatted as strings.
Examples
If just getting started, use the Flux REPL or the InfluxDB Data Explorer to execute Flux queries.
- Query an annotated CSV string
- Query a raw CSV string
- Query CSV data from a file
- Query CSV data from a URL
Query an annotated CSV string
- Import the
csv
package. - Use
csv.from()
and thecsv
parameter to specify the annotated CSV string to query.
Query
import "csv"
csvData =
"
#group,false,false,true,true,true,false,false
#datatype,string,long,string,string,string,long,double
#default,_result,,,,,,
,result,table,dataset,metric,sensorID,timestamp,value
,,0,air-sensors,humidity,TLM0100,1627049400000000000,34.79
,,0,air-sensors,humidity,TLM0100,1627049700000000000,34.65
,,1,air-sensors,humidity,TLM0200,1627049400000000000,35.64
,,1,air-sensors,humidity,TLM0200,1627049700000000000,35.67
,,2,air-sensors,temperature,TLM0100,1627049400000000000,71.84
,,2,air-sensors,temperature,TLM0100,1627049700000000000,71.87
,,3,air-sensors,temperature,TLM0200,1627049400000000000,74.10
,,3,air-sensors,temperature,TLM0200,1627049700000000000,74.17
"
csv.from(csv: csvData)
Results
dataset | metric | sensorID | timestamp | value |
---|---|---|---|---|
air-sensors | humidity | TLM0100 | 1627049400000000000 | 34.79 |
air-sensors | humidity | TLM0100 | 1627049700000000000 | 34.65 |
dataset | metric | sensorID | timestamp | value |
---|---|---|---|---|
air-sensors | humidity | TLM0200 | 1627049400000000000 | 35.64 |
air-sensors | humidity | TLM0200 | 1627049700000000000 | 35.67 |
dataset | metric | sensorID | timestamp | value |
---|---|---|---|---|
air-sensors | temperature | TLM0100 | 1627049400000000000 | 71.84 |
air-sensors | temperature | TLM0100 | 1627049700000000000 | 71.87 |
dataset | metric | sensorID | timestamp | value |
---|---|---|---|---|
air-sensors | temperature | TLM0200 | 1627049400000000000 | 74.10 |
air-sensors | temperature | TLM0200 | 1627049700000000000 | 74.17 |
Query a raw CSV string
Import the
csv
package.Use
csv.from()
and provide the following parameters:- csv: CSV string to query
- mode: raw
Query
import "csv"
csvData =
"
dataset,metric,sensorID,timestamp,value
air-sensors,humidity,TLM0100,1627049400000000000,34.79
air-sensors,humidity,TLM0100,1627049700000000000,34.65
air-sensors,humidity,TLM0200,1627049400000000000,35.64
air-sensors,humidity,TLM0200,1627049700000000000,35.67
air-sensors,temperature,TLM0100,1627049400000000000,71.84
air-sensors,temperature,TLM0100,1627049700000000000,71.87
air-sensors,temperature,TLM0200,1627049400000000000,74.10
air-sensors,temperature,TLM0200,1627049700000000000,74.17
"
csv.from(csv: csvData, mode: "raw")
Results
When using the raw CSV parsing mode, all columns values are strings.
dataset | metric | sensorID | timestamp | value |
---|---|---|---|---|
air-sensors | humidity | TLM0100 | 1627049400000000000 | 34.79 |
air-sensors | humidity | TLM0100 | 1627049700000000000 | 34.65 |
air-sensors | humidity | TLM0200 | 1627049400000000000 | 35.64 |
air-sensors | humidity | TLM0200 | 1627049700000000000 | 35.67 |
air-sensors | temperature | TLM0100 | 1627049400000000000 | 71.84 |
air-sensors | temperature | TLM0100 | 1627049700000000000 | 71.87 |
air-sensors | temperature | TLM0200 | 1627049400000000000 | 74.10 |
air-sensors | temperature | TLM0200 | 1627049700000000000 | 74.17 |
Query CSV data from a file
- Import the
csv
package. - Use
csv.from()
and thefile
parameter to query CSV data from a file.
Flux must have access to the file system
To query CSV data from a file, Flux must have access to the filesystem. If Flux does not have access to the file system, the query will return an error similar to:
failed to read file: filesystem service is uninitialized
If using InfluxDB Cloud or InfluxDB OSS, the Flux process does not have access to the filesystem.
Query
import "csv"
csv.from(file: "/path/to/example.csv")
/path/to/example.csv
#group,false,false,true,true,true,false,false
#datatype,string,long,string,string,string,long,double
#default,_result,,,,,,
,result,table,dataset,metric,sensorID,timestamp,value
,,0,air-sensors,humidity,TLM0100,1627049400000000000,34.79
,,0,air-sensors,humidity,TLM0100,1627049700000000000,34.65
,,1,air-sensors,humidity,TLM0200,1627049400000000000,35.64
,,1,air-sensors,humidity,TLM0200,1627049700000000000,35.67
,,2,air-sensors,temperature,TLM0100,1627049400000000000,71.84
,,2,air-sensors,temperature,TLM0100,1627049700000000000,71.87
,,3,air-sensors,temperature,TLM0200,1627049400000000000,74.10
,,3,air-sensors,temperature,TLM0200,1627049700000000000,74.17
Results
dataset | metric | sensorID | timestamp | value |
---|---|---|---|---|
air-sensors | humidity | TLM0100 | 1627049400000000000 | 34.79 |
air-sensors | humidity | TLM0100 | 1627049700000000000 | 34.65 |
dataset | metric | sensorID | timestamp | value |
---|---|---|---|---|
air-sensors | humidity | TLM0200 | 1627049400000000000 | 35.64 |
air-sensors | humidity | TLM0200 | 1627049700000000000 | 35.67 |
dataset | metric | sensorID | timestamp | value |
---|---|---|---|---|
air-sensors | temperature | TLM0100 | 1627049400000000000 | 71.84 |
air-sensors | temperature | TLM0100 | 1627049700000000000 | 71.87 |
dataset | metric | sensorID | timestamp | value |
---|---|---|---|---|
air-sensors | temperature | TLM0200 | 1627049400000000000 | 74.10 |
air-sensors | temperature | TLM0200 | 1627049700000000000 | 74.17 |
Query CSV data from a URL
- Import the
experimental/csv
package. - Use the experimental
csv.from()
function andurl
parameter to specify the URL to query.
The experimental csv.from()
function does not support multiple parsing modes
and only works with annotated CSV.
import "experimental/csv"
csv.from(url: "https://example.com/example.csv")
To use the parsing modes available in csv.from()
:
- Import the
csv
andexperimental/http
packages. - Use
http.get()
to fetch the CSV data. - Use
string()
to convert the response body to a string. - Use
csv.from()
to parse the CSV data and return results.
import "csv"
import "experimental/http"
url = "https://example.com/example.csv"
csvData = string(v: http.get(url: url).body)
csv.from(csv: csvData, mode: "raw")
Was this page helpful?
Thank you for your feedback!
Support and feedback
Thank you for being part of our community! We welcome and encourage your feedback and bug reports for Flux and this documentation. To find support, use the following resources:
Customers with an annual or support contract can contact InfluxData Support.