2013-11-22 19:32:53 -05:00
---
layout: doc_page
---
2014-01-16 18:37:07 -05:00
# Transforming Dimension Values
The following JSON fields can be used in a query to operate on dimension values.
2013-11-22 19:32:53 -05:00
## DimensionSpec
`DimensionSpec` s define how dimension values get transformed prior to aggregation.
### DefaultDimensionSpec
2014-01-16 18:37:07 -05:00
Returns dimension values as is and optionally renames the dimension.
2013-11-22 19:32:53 -05:00
```json
{ "type" : "default", "dimension" : < dimension > , "outputName": < output_name > }
```
### ExtractionDimensionSpec
Returns dimension values transformed using the given [DimExtractionFn ](#toc_3 )
```json
{
"type" : "extraction",
"dimension" : < dimension > ,
"outputName" : < output_name > ,
"dimExtractionFn" : < dim_extraction_fn >
}
```
## DimExtractionFn
2014-11-13 09:35:09 -05:00
`DimExtractionFn` s define the transformation applied to each dimension value
2013-11-22 19:32:53 -05:00
### RegexDimExtractionFn
Returns the first group matched by the given regular expression. If there is no match it returns the dimension value as is.
```json
{ "type" : "regex", "expr", < regular_expression > }
```
### PartialDimExtractionFn
Returns the dimension value as is if there is a match, otherwise returns null.
```json
{ "type" : "partial", "expr", < regular_expression > }
```
### SearchQuerySpecDimExtractionFn
Returns the dimension value as is if the given [SearchQuerySpec ](SearchQuerySpec.html ) matches, otherwise returns null.
```json
{ "type" : "searchQuery", "query" : < search_query_spec > }
```
### TimeDimExtractionFn
Parses dimension values as timestamps using the given input format, and returns them formatted using the given output format. Time formats follow the [com.ibm.icu.text.SimpleDateFormat ](http://icu-project.org/apiref/icu4j/com/ibm/icu/text/SimpleDateFormat.html ) format
```json
{ "type" : "time", "timeFormat" : < input_format > , "resultFormat" : < output_format > }
```
### JavascriptDimExtractionFn
Returns the dimension value as transformed by the given JavaScript function.
Example
```json
{
"type" : "javascript",
"function" : "function(str) { return str.substr(0, 3); }"
}