“文档” 菜单
文档首页
/
MongoDB Manual
/ / /

$trim(聚合)

在此页面上

  • 定义
  • 行为
  • 例子
$trim

删除字符串开头和结尾的空格字符(包括 null)或指定的字符。

$trim 通过以下语法实现:

{ $trim: { input: <string>, chars: <string> } }

$trim 接受包含以下字段的文档:

字段
说明
input
要修剪的字符串。参数可以是任何解析为字符串的有效表达式。有关表达式的更多信息,请参阅表达式操作符。
chars

可选。要从 input 中修剪的字符。

该参数可以是解析为字符串的任何有效表达式$trim 操作符将字符串分解为单独的 UTF 代码点,以便从 input 进行修剪。

如果未指定,$trim 会删除空白字符,包括 null 字符。有关空白字符列表,请参阅空白字符。

提示

另请参阅:

  • 默认情况下,$trim 会删除空白字符,包括空字符:

    例子
    结果
    { $trim: { input: " \n good bye \t " } }
    "good bye"
  • 可使用 chars 字段覆盖待修剪的默认字符。

    例如,以下代码会从输入的开始和结束处删除任何 ge。由于输入以空格开头,因此不能从字符串的开头修剪这两个字符。

    例子
    结果
    { $trim: { input: " ggggoodbyeeeee", chars: "ge" } }
    " ggggoodby"
  • 如果覆盖待修剪的默认字符,则可以在 chars 字段中明确包含待修剪的空白字符。

    例如,以下代码会删除输入开头和结尾处的所有空格、ge

    例子
    结果
    { $trim: { input: " ggggoodbyeeeee", chars: " ge" } }
    "oodby"

默认情况下,$trim 会删除以下空格,包括空字符:

Unicode
转义序列
说明
U+0000
' 0 '
Null 字符
U+0020
' '
空格
U+0009
't'
水平制表符
U+000A
'n'
换行/新行
U+000B
'v'
垂直制表符
U+000C
'f'
换页
U+000D
'r'
回车
U+00A0
不间断空格
U+1680
欧甘文空格标记
U+2000
Enquad
U+2001
Emquad
U+2002
En 空格
U+2003
Em 空格
U+2004
三个全角空格
U+2005
四个 em 空格
U+2006
六个全角空格
U+2007
数字空格
U+2008
标点符号空格
U+2009
窄空格
U+200A
发宽空格

考虑包含以下文档的 inventory 集合:

{ "_id" : 1, "item" : "ABC1", quarter: "13Q1", "description" : " product 1" }
{ "_id" : 2, "item" : "ABC2", quarter: "13Q4", "description" : "product 2 \n The product is in stock. \n\n " }
{ "_id" : 3, "item" : "XYZ1", quarter: "14Q2", "description" : null }

以下操作使用 $trim 操作符从 description 字段中删除前导和结尾的空格:

db.inventory.aggregate([
{ $project: { item: 1, description: { $trim: { input: "$description" } } } }
])

操作返回以下结果:

{ "_id" : 1, "item" : "ABC1", "description" : "product 1" }
{ "_id" : 3, "item" : "XYZ1", "description" : null }
{ "_id" : 2, "item" : "ABC2", "description" : "product 2 \n The product is in stock." }

后退

$tsSecond(聚合)

来年

$trunc(聚合)

在此页面上