- NAME
-
- gcloud alpha topic projections - resource projections supplementary help
- DESCRIPTION
-
(ALPHA)
Mostgcloud
commands return a list of resources on success. By default they are pretty-printed on the standard output. The--format=
NAME
[ATTRIBUTES
](
PROJECTION
)
and--filter=
EXPRESSION
flags along with projections can be used to format and change the default output to a more meaningful result.Use the
--format
flag to change the default output format of a command. For details run $ gcloud topic formats.Use the
--filter
flag to select resources to be listed. For details run $ gcloud topic filters.Use resource-keys to reach resource items through a unique path of names from the root. For details run $ gcloud topic resource-keys.
Use projections to list a subset of resource keys in a resource. Resource projections are described in detail below.
Note: To refer to a list of fields you can sort, filter, and format by for each resource, you can run a list command with the format set to
text
orjson
. For example, $ gcloud compute instances list --limit=1 --format=text.To work through an interactive tutorial about using the filter and format flags instead, see: https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/GoogleCloudPlatform/cloud-shell-tutorials&page=editor&tutorial=cloudsdk/tutorial.md
- Projections
-
A projection is a list of keys that selects resource data values. Projections
are used in
--format
flag expressions. For example, thetable
format requires a projection that describes the table columns:table(name, network.ip.internal, network.ip.external, uri())
- Transforms
-
A
transform
formats resource data values. Each projection key may have zero or more transform calls:_key_._transform_([arg…])…
This example applies the
foo
() and then thebar
() transform to thestatus.time
resource value: The builtin transform functions are:(name, status.time.foo().bar())
always
()-
Marks a transform sequence to always be applied.
In some cases transforms are disabled. Prepending always() to a transform sequence causes the sequence to always be evaluated.
For example:
some_field.always().foo().bar()
- Always applies foo() and then bar().
basename
(undefined="")-
Returns the last path component.
The arguments are:
undefined
- Returns this value if the resource or basename is empty.
collection
(undefined="")-
Returns the current resource collection.
The arguments are:
undefined
- This value is returned if r or the collection is empty.
color
(red, yellow, green, blue)-
Colorizes the resource string value.
The
red
,yellow
,green
andblue
args are RE patterns, matched against the resource in order. The first pattern that matches colorizes the matched substring with that color, and the other patterns are skipped.The arguments are:
red
- The substring pattern for the color red.
yellow
- The substring pattern for the color yellow.
green
- The substring pattern for the color green.
blue
- The substring pattern for the color blue.
For example:
color(red=STOP,yellow=CAUTION,green=GO)
- For the resource string "CAUTION means GO FASTER" displays the substring "CAUTION" in yellow.
count
()-
Counts the number of each item in the list.
A string resource is treated as a list of characters.
For example:
"b/a/b/c".split("/").count()
returns{a: 1, b: 2, c: 1}
.
date
(format="%Y-%m-%dT%H:%M:%S", unit=1, undefined="", tz, tz_default)-
Formats the resource as a strftime() format.
The arguments are:
format
- The strftime(3) format.
unit
-
If the resource is a Timestamp then divide by
unit
to yield seconds.
undefined
- Returns this value if the resource is not a valid time.
tz
-
Return the time relative to the tz timezone if specified, the explicit timezone
in the resource if it has one, otherwise the local timezone. For example:
date(tz=EST5EDT, tz_default=UTC)
.
tz_default
- The default timezone if the resource does not have a timezone suffix.
decode
(encoding, undefined="")-
Returns the decoded value of the resource that was encoded by encoding.
The arguments are:
encoding
-
The encoding name.
base64
andutf-8
are supported.
undefined
- Returns this value if the decoding fails.
duration
(start="", end="", parts=3, precision=3, calendar=true, unit=1, undefined="")-
Formats the resource as an ISO 8601 duration string.
The ISO 8601 Duration format is: "[-]P[nY][nM][nD][T[nH][nM][n[.m]S]]". The 0 duration is "P0". Otherwise at least one part will always be displayed. Negative durations are prefixed by "-". "T" disambiguates months "P2M" to the left of "T" and minutes "PT5M" to the right.
If the resource is a datetime then the duration of
resource - current_time
is returned.The arguments are:
start
-
The name of a start time attribute in the resource. The duration of the
end - start
time attributes in resource is returned. Ifend
is not specified then the current time is used.
end
-
The name of an end time attribute in the resource. Defaults to the current time
if omitted. Ignored if
start
is not specified.
parts
- Format at most this many duration parts starting with largest non-zero part.
precision
- Format the last duration part with precision digits after the decimal point. Trailing "0" and "." are always stripped.
calendar
-
Allow time units larger than hours in formatted durations if true. Durations
specifying hours or smaller units are exact across daylight savings time
boundaries. On by default. Use calendar=false to disable. For example, if
calendar=true
then at the daylight savings boundary 2016-03-13T01:00:00 + P1D => 2016-03-14T01:00:00 but 2016-03-13T01:00:00 + PT24H => 2016-03-14T03:00:00. Similarly, a +P1Y duration will be inexact but "calendar correct", yielding the same month and day number next year, even in leap years.
unit
-
Divide the resource numeric value by
unit
to yield seconds.
undefined
- Returns this value if the resource is not a valid timestamp.
For example:
duration(start=createTime,end=updateTime)
- The duration from resource creation to the most recent update.
updateTime.duration()
- The duration since the most recent resource update.
encode
(encoding, undefined="")-
Returns the encoded value of the resource using encoding.
The arguments are:
encoding
-
The encoding name.
base64
andutf-8
are supported.
undefined
- Returns this value if the encoding fails.
enum
(enums, inverse=false, undefined="")-
Returns the enums dictionary description for the resource.
The arguments are:
enums
- The name of a message enum dictionary.
inverse
- Do inverse lookup if true.
undefined
- Returns this value if there is no matching enum description.
error
(message)-
Raises an Error exception that does not generate a stack trace.
The arguments are:
message
- An error message. If not specified then the resource is formatted as the error message.
extract
(keys)-
Extract a list of non-empty values for the specified resource keys.
The arguments are:
keys
- The list of keys in the resource whose non-empty values will be included in the result.
fatal
(message)-
Raises an InternalError exception that generates a stack trace.
The arguments are:
message
- An error message. If not specified then the resource is formatted as the error message.
filter
(expression)-
Selects elements of x that match the filter expression.
The arguments are:
expression
- The filter expression to apply to r.
For example:
x.filter("key:val")
selects elements of x that have 'key' fields containing 'val'.
firstof
(keys)-
Returns the first non-empty attribute value for key in keys.
The arguments are:
keys
- Keys to check for resource attribute values,
For example:
x.firstof(bar_foo, barFoo, BarFoo, BAR_FOO)
- Checks x.bar_foo, x.barFoo, x.BarFoo, and x.BAR_FOO in order for the first non-empty value.
flatten
(show="", undefined="", separator=",")-
Formats nested dicts and/or lists into a compact comma separated list.
The arguments are:
show
-
If show=
keys
then list dict keys; if show=values
then list dict values; otherwise list dict key=value pairs.
undefined
- Return this if the resource is empty.
separator
- The list item separator string.
For example:
--format="table(field.map(2).list().map().list().list()"
- Expression with explicit flattening.
--format="table(field.flatten()"
- Equivalent expression using .flatten().
float
(precision=6, spec, undefined="")-
Returns the string representation of a floating point number.
One of these formats is used (1) ".
precision
spec
" ifspec
is specified (2) ".precision
" unless 1e-04 <= abs(number) < 1e+09 (3) ".1f" otherwise.The arguments are:
precision
- The maximum number of digits before and after the decimal point.
spec
- The printf(3) floating point format "e", "f" or "g" spec character.
undefined
- Returns this value if the resource is not a float.
format
(fmt, args)-
Formats resource key values.
The arguments are:
fmt
- The format string with {0} … {nargs-1} references to the resource attribute name arg values.
args
- The resource attribute key expression to format. The printer projection symbols and aliases may be used in key expressions. If no args are specified then the resource is used as the arg list if it is a list, otherwise the resource is used as the only arg.
For example:
--format='value(format("{0:f.1}/{1:f.1}", q.CPU.default, q.CPU.limit))'
- Formats q.CPU.default and q.CPU.limit as floating point numbers.
group
(keys)-
Formats a […] grouped list.
Each group is enclosed in […]. The first item separator is ':', subsequent separators are ','. [item1] [item1] … [item1: item2] … [item1: item2] [item1: item2, item3] … [item1: item2, item3]
The arguments are:
keys
- Optional attribute keys to select from the list. Otherwise the string value of each list item is selected.
if
(expr)-
Disables the projection key if the flag name filter expr is false.
The arguments are:
expr
-
A command flag filter name expression. See
gcloud topic filters
for details on filter expressions. The expression variables are flag names without the leading--
prefix and dashes replaced by underscores.
For example:
table(name, value.if(NOT short_format))
-
Lists a value column if the
--short-format
command line flag is not specified.
iso
(undefined="T")-
Formats the resource to numeric ISO time format.
The arguments are:
undefined
- Returns this value if the resource does not have an isoformat() attribute.
join
(sep="/", undefined="")-
Joins the elements of the resource list by the value of sep.
A string resource is treated as a list of characters.
The arguments are:
sep
- The separator value to use when joining.
undefined
- Returns this value if the result after joining is empty.
For example:
"a/b/c/d".split("/").join("!")
returns"a!b!c!d"
.
len
()- Returns the length of the resource if it is non-empty, 0 otherwise.
list
(show="", undefined="", separator=",")-
Formats a dict or list into a compact comma separated list.
The arguments are:
show
-
If show=
keys
then list dict keys; if show=values
then list dict values; otherwise list dict key=value pairs.
undefined
- Return this if the resource is empty.
separator
- The list item separator string.
lower
()- Returns r in lowercase.
map
(depth=1)-
Applies the next transform in the sequence to each resource list item.
The arguments are:
depth
- The list nesting depth.
For example:
list_field.map().foo().list()
- Applies foo() to each item in list_field and then list() to the resulting value to return a compact comma-separated list.
list_field.*foo().list()
-
*
is shorthand for map(). list_field.map().foo().map().bar()
- Applies foo() to each item in list_field and then bar() to each item in the resulting list.
abc.xyz.map(2).foo()
- Applies foo() to each item in xyz[] for all items in abc[].
abc.xyz.**foo()
-
**
is shorthand for map(2).
notnull
()- Remove null values from the resource list.
regex
(expression, does_match, nomatch="")-
Returns does_match or r itself if r matches expression, nomatch otherwise.
The arguments are:
expression
- expression to apply to r.
does_match
-
If the string matches expression then return
does_match
otherwise return the string itself ifdoes_match
is not defined.
nomatch
- Returns this value if the string does not match expression.
resolution
(undefined="", transpose=false)-
Formats a human readable XY resolution.
The arguments are:
undefined
- Returns this value if a recognizable resolution was not found.
transpose
- Returns the y/x resolution if true.
scope
(args)-
Gets the /args/ suffix from a URI.
The arguments are:
args
- Optional URI segment names. If not specified then 'regions', 'zones' is assumed.
For example:
"http://abc/foo/projects/bar/xyz".scope("projects")
returns"bar/xyz"
."http://xyz/foo/regions/abc".scope()
returns"abc"
.
segment
(index=-1, undefined="")-
Returns the index-th URI path segment.
The arguments are:
index
- The path segment index to return counting from 0.
undefined
- Returns this value if the resource or segment index is empty.
size
(zero="0", precision=1, units_in, units_out, min=0)-
Formats a human readable size in bytes.
The arguments are:
zero
- Returns this if size==0. Ignored if None.
precision
- The number of digits displayed after the decimal point.
units_in
- A unit suffix (only the first character is checked) or unit size. The size is multiplied by this. The default is 1.0.
units_out
- A unit suffix (only the first character is checked) or unit size. The size is divided by this. The default is 1.0.
min
-
Sizes <
min
will be listed as "<min
".
slice
(op=":", undefined="")-
Returns a list slice specified by op.
The op parameter consists of up to three colon-delimeted integers: start, end, and step. The parameter supports half-open ranges: start and end values can be omitted, representing the first and last positions of the resource respectively.
The step value represents the increment between items in the resource included in the slice. A step of 2 results in a slice that contains every other item in the resource.
Negative values for start and end indicate that the positons should start from the last position of the resource. A negative value for step indicates that the slice should contain items in reverse order.
If op contains no colons, the slice consists of the single item at the specified position in the resource.
The arguments are:
op
- The slice operation.
undefined
- Returns this value if the slice cannot be created, or the resulting slice is empty.
For example:
[1,2,3].slice(1:)
returns[2,3]
.[1,2,3].slice(:2)
returns[1,2]
.[1,2,3].slice(-1:)
returns[3]
.[1,2,3].slice(: :-1)
returns[3,2,1]
.[1,2,3].slice(1)
returns[2]
.
sort
(attr="")-
Sorts the elements of the resource list by a given attribute (or itself).
A string resource is treated as a list of characters.
The arguments are:
attr
- The optional field of an object or dict by which to sort.
For example:
"b/a/d/c".split("/").sort()
returns[a, b, c, d]
.
split
(sep="/", undefined="")-
Splits a string by the value of sep.
The arguments are:
sep
- The separator value to use when splitting.
undefined
- Returns this value if the result after splitting is empty.
For example:
"a/b/c/d".split()
returns["a", "b", "c", "d"]
.
sub
(pattern, replacement, count=0, ignorecase=true)-
Replaces a pattern matched in a string with the given replacement.
Return the string obtained by replacing the leftmost non-overlapping occurrences of pattern in the string by replacement. If the pattern isn't found, then the original string is returned unchanged.
The arguments are:
pattern
- The regular expression pattern to match in r that we want to replace with something.
replacement
- The value to substitute into whatever pattern is matched.
count
- The max number of pattern occurrences to be replaced. Must be non-negative. If omitted or zero, all occurrences will be replaces.
ignorecase
- Whether to perform case-insensitive matching.
For example:
table(field.sub(" there", ""))
- If the field string is "hey there" it will be displayed as "hey".
synthesize
(args)-
Synthesizes a new resource from the schema arguments.
A list of tuple arguments controls the resource synthesis. Each tuple is a schema that defines the synthesis of one resource list item. Each schema item defines the synthesis of one synthesized_resource attribute from an original_resource attribute.
There are three kinds of schema items:
name:literal
- The value for the name attribute in the synthesized resource is the literal value.
name=key
- The value for the name attribute in the synthesized_resource is the value of key in the original_resource.
key
- All the attributes of the value of key in the original_resource are added to the attributes in the synthesized_resource.
The arguments are:
args
- The list of schema tuples.
For example:
- This returns a list of two resource items
-
synthesize((name:up, upInfo), (name:down, downInfo))
- If upInfo and downInfo serialize to
-
{"foo": 1, "bar": "yes"}
- and
-
{"foo": 0, "bar": "no"}
- then the synthesized resource list is
-
[{"name": "up", "foo": 1, "bar": "yes"}, {"name": "down", "foo": 0, "bar": "no"}]
- This could then be displayed by a nested table using
-
synthesize(…):format="table(name, foo, bar)"
trailoff
(character_limit, undefined="")-
Returns r if less than limit, else abbreviated r followed by ellipsis.
The arguments are:
character_limit
- An int. Max length of return string. Must be greater than 3 because ellipsis (3 chars) is appended to abridged strings.
undefined
- A string. Return if r or character_limit is invalid.
upper
()- Returns r in uppercase.
uri
(undefined=".")-
Gets the resource URI.
The arguments are:
undefined
- Returns this if a the URI for r cannot be determined.
yesno
(yes, no="No")-
Returns no if the resource is empty, yes or the resource itself otherwise.
The arguments are:
yes
-
If the resource is not empty then returns
yes
or the resource itself ifyes
is not defined.
no
- Returns this value if the resource is empty.
build_images
(undefined="")-
Returns the formatted build results images.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
build_source
(undefined="")-
Returns the formatted build source.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
result_duration
(resource, undefined="")-
Returns the formatted result duration.
The arguments are:
resource
- JSON-serializable object.
undefined
- Returns this value if the resource cannot be formatted.
result_status
(resource, undefined="")-
Returns the formatted result status.
The arguments are:
resource
- JSON-serializable object.
undefined
- Returns this value if the resource cannot be formatted.
firewall_rule
(undefined="")-
Returns a compact string describing a firewall rule.
The compact string is a comma-separated list of PROTOCOL:PORT_RANGE items. If a particular protocol has no port ranges then only the protocol is listed.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
image_alias
(undefined="")-
Returns a comma-separated list of alias names for an image.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
location
(undefined="")-
Return the region or zone name.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
location_scope
(undefined="")-
Return the location scope name, either region or zone.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
machine_type
(undefined="")-
Return the formatted name for a machine type.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
name
(undefined="")-
Returns a resource name from an URI.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
next_maintenance
(undefined="")-
Returns the timestamps of the next scheduled maintenance.
All timestamps are assumed to be ISO strings in the same timezone.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
operation_http_status
(undefined="")-
Returns the HTTP response code of an operation.
The arguments are:
undefined
- Returns this value if there is no response code.
org_firewall_rule
(rule, undefined="")-
Returns a compact string describing an organization firewall rule.
The compact string is a comma-separated list of PROTOCOL:PORT_RANGE items. If a particular protocol has no port ranges then only the protocol is listed.
The arguments are:
rule
- JSON-serializable object.
undefined
- Returns this value if the resource cannot be formatted.
project
(undefined="")-
Returns a project name from a selfLink.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
quota
(undefined="")-
Formats a quota as usage/limit.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
scoped_suffixes
(uris, undefined="")- Get just the scoped part of the object the uri refers to.
status
(undefined="")-
Returns the machine status with deprecation information if applicable.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
type_suffix
(uri, undefined="")- Get the type and the name of the object the uri refers to.
vpn_tunnel_gateway
(vpn_tunnel, undefined="")-
Returns the gateway for the specified VPN tunnel resource if applicable.
The arguments are:
vpn_tunnel
- JSON-serializable object of a VPN tunnel.
undefined
- Returns this value if the resource cannot be formatted.
zone
(undefined="")-
Returns a zone name from a selfLink.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
master_version
(undefined="")-
Returns the formatted master version.
The arguments are:
undefined
- Returns this value if the resource cannot be formatted.
full_status
(undefined="UNKNOWN_ERROR")-
Returns a full description of the status of a logpoint or snapshot.
Status will be one of ACTIVE, COMPLETED, or a verbose error description. If the status is an error, there will be additional information available in the status field of the object.
The arguments are:
undefined
- Returns this value if the resource is not a valid status.
For example:
--format="table(id, location, full_status())"
- Displays the full status in the third table problem.
short_status
(undefined="UNKNOWN_ERROR")-
Returns a short description of the status of a logpoint or snapshot.
Status will be one of ACTIVE, COMPLETED, or a short error description. If the status is an error, there will be additional information available in the status field of the object.
The arguments are:
undefined
- Returns this value if the resource is not a valid status.
For example:
--format="table(id, location, short_status())"
- Displays the short status in the third table problem.
environments
(data)-
Returns the supported environments for a runtime.
The arguments are:
data
- JSON-serializable Runtimes object.
generation
(data, undefined="-")-
Returns Cloud Functions product version.
The arguments are:
data
- JSON-serializable 1st and 2nd gen Functions objects.
undefined
- Returns this value if the resource cannot be formatted.
state
(data, undefined="")-
Returns textual information about functions state.
The arguments are:
data
- JSON-serializable object.
undefined
- Returns this value if the resource cannot be formatted.
trigger
(data, undefined="")-
Returns textual information about functions trigger.
The arguments are:
data
- JSON-serializable 1st and 2nd gen Functions objects.
undefined
- Returns this value if the resource cannot be formatted.
waiter_status
(undefined="")-
Returns a short description of the status of a waiter or waiter operation.
Status will be one of WAITING, SUCCESS, FAILURE, or TIMEOUT.
The arguments are:
undefined
- Returns this value if the resource status cannot be determined.
For example:
--format="table(name, status())"
- Displays the status in table column two.
- Key Attributes
-
Key attributes control formatted output. Each projection key may have zero or
more attributes:
_key_:_attribute_=_value_…
where =
value
is omitted for Boolean attributes and no-attribute
sets the attribute to false. Attribute values may appear in any order, but must be specified after any transform calls. The attributes are:alias
=ALIAS-NAME
-
Sets
ALIAS-NAME
as an alias for the projection key. align
=ALIGNMENT
-
Specifies the output column data alignment. Used by the
table
format. The alignment values are:left
- Left (default).
center
- Center.
right
- Right.
label
=LABEL
-
A string value used to label output. Use :label="" or :label='' for no label.
The
table
format usesLABEL
values as column headings. Also setsLABEL
as an alias for the projection key. The default label is the disambiguated right hand parts of the column key name in ANGRY_SNAKE_CASE. - [no-]
reverse
-
Sets the key sort order to descending.
no-reverse
resets to the default ascending order. sort
=SORT-ORDER
- An integer counting from 1. Keys with lower sort-order are sorted first. Keys with same sort order are sorted left to right. Columns are sorted based on displayed value alone, irrespective of the type of value(date, time, etc.).
wrap
[=MIN-WIDTH
]-
Enables the column text to be wrapped if the table would otherwise be too wide
for the display. The column will be wrapped in the available space with a
minimum width of either the default or of
MIN-WIDTH
if specified. The default is 10 characters. width
=COLUMN-WIDTH
- An integer denoting the width for the column. The default fits the table to the terminal width or 80 if the output is not a terminal.
- EXAMPLES
-
List a table of instance
zone
(sorted in descending order) andname
(sorted byname
and centered with column headingINSTANCE
) andcreationTimestamp
(listed using thestrftime
(3) year-month-day format with column headingSTART
):gcloud compute instances list --format="table(name:sort=2:align=center:label=INSTANCE, zone:sort=1:reverse, creationTimestamp.date("%Y-%m-%d"):label=START)"
List only the
name
,status
andzone
instance resource keys in YAML format:gcloud compute instances list --format="yaml(name, status, zone)"
List only the
config.account
key value(s) in theinfo
resource:gcloud info --format="value(config.account)"
List the
name
,id
, anddescription
of an imaginaryfoo
resource, fixing thename
column width to 16 characters, wrapping theid
column with the default minimum width and thedescription
column with a minimum width of 20 characters:gcloud example foo list --format="table(name:width=16, id:wrap, description:wrap=20)"
- NOTES
-
This command is currently in alpha and might change without notice. If this
command fails with API permission errors despite specifying the correct project,
you might be trying to access an API with an invitation-only early access
allowlist. These variants are also available:
gcloud topic projections
gcloud beta topic projections
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2024-02-21 UTC.