$ReplaceAll - Amazon DocumentDB

Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.

$ReplaceAll

Introducido en 5.0

El $replaceAll operador de Amazon DocumentDB se utiliza para reemplazar todas las apariciones de un patrón de cadenas especificado dentro de un campo por una cadena nueva. Este operador puede resultar útil para tareas como la normalización de datos, la limpieza de texto y la manipulación de cadenas.

Parámetros

  • input: el campo o la expresión que contiene la cadena que se va a reemplazar.

  • find: el patrón de cadenas que se va a buscar y reemplazar.

  • replacement: La cadena con la que se van a reemplazar las apariciones coincidentes.

Ejemplo (MongoDB Shell)

El siguiente ejemplo muestra cómo utilizar el $replaceAll operador en una canalización de agregación para reemplazar todas las apariciones de la cadena «Chocolatier» por «Chocolate Co». en el campo «Nombre de la marca» de una colección de «productos».

Cree documentos de muestra

db.products.insertMany([ { "_id": 1, "productId": "PROD-0Y9GL0", "brandName": "Gordon's Chocolatier", "category": "CPG", "rating": { "average": 4.8 } }, { "_id": 2, "productId": "PROD-1X2YZ3", "brandName": "Premium Chocolatier", "category": "CPG", "rating": { "average": 4.5 } }, { "_id": 3, "productId": "PROD-Y2E9H5", "name": "Nutrition Co. - Original Corn Flakes Cereal", "category": "Breakfast Cereals", "price": 8.5 } ]);

Ejemplo de consulta

db.products.aggregate([ { $addFields: { "brandName": { $replaceAll: { input: "$brandName", find: "Chocolatier", replacement: "Chocolate Co." } } } } ])

Salida

[ { _id: 1, productId: 'PROD-0Y9GL0', brandName: "Gordon's Chocolate Co.", category: 'CPG', rating: { average: 4.8 } }, { _id: 2, productId: 'PROD-1X2YZ3', brandName: 'Premium Chocolate Co.', category: 'CPG', rating: { average: 4.5 } }, { _id: 3, productId: 'PROD-Y2E9H5', name: 'Nutrition Co. - Original Corn Flakes Cereal', category: 'Breakfast Cereals', price: 8.5, brandName: null } ]

Ejemplos de código

Para ver un ejemplo de código para usar el $replaceAll comando, elija la pestaña del idioma que desee usar:

Node.js
const { MongoClient } = require('mongodb'); async function replaceAll() { const client = await MongoClient.connect('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false'); const db = client.db('test'); const collection = db.collection('products'); const results = await collection.aggregate([ { $addFields: { "brandName": { $replaceAll: { input: "$brandName", find: "Chocolatier", replacement: "Chocolate Co." } } } } ]).toArray(); console.log(results); await client.close(); } replaceAll();
Python
from pymongo import MongoClient def replace_all(): client = MongoClient('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false') db = client.test collection = db.products results = list(collection.aggregate([ { "$addFields": { "brandName": { "$replaceAll": { "input": "$brandName", "find": "Chocolatier", "replacement": "Chocolate Co." } } } } ])) print(results) client.close() replace_all()