content/shared/influxdb-v2/query-data/flux/regular-expressions.md
Regular expressions (regexes) are incredibly powerful when matching patterns in large collections of data. With Flux, regular expressions are primarily used for evaluation logic in predicate functions for things such as filtering rows, dropping and keeping columns, state detection, etc. This guide shows how to use regular expressions in your Flux scripts.
If you're just getting started with Flux queries, check out the following:
Flux uses Go's regexp package for regular expression search. The links below provide information about Go's regular expression syntax.
Flux provides two comparison operators for use with regular expressions.
=~When the expression on the left MATCHES the regular expression on the right, this evaluates to true.
!~When the expression on the left DOES NOT MATCH the regular expression on the right, this evaluates to true.
When using regex matching in your Flux scripts, enclose your regular expressions with /.
The following is the basic regex comparison syntax:
expression =~ /regex/
expression !~ /regex/
The following example filters records by the cpu tag.
It only keeps records for which the cpu is either cpu0, cpu1, or cpu2.
from(bucket: "example-bucket")
|> range(start: -15m)
|> filter(fn: (r) => r._measurement == "cpu" and r.cpu =~ /cpu[0-2]$/)
The following example excludes records that do not have _percent in a field key.
from(bucket: "example-bucket")
|> range(start: -15m)
|> filter(fn: (r) => r._measurement == "mem" and r._field =~ /_percent/)
The following example drops columns whose names do not begin with _.
from(bucket: "example-bucket")
|> range(start: -15m)
|> filter(fn: (r) => r._measurement == "mem")
|> drop(fn: (column) => column !~ /^_.*/)
regexp Syntax GoDoc
RE2 Syntax Overview