FindReplaceDirection
Contenido
[
Ocultar
]FindReplaceDirection enumeration
Especifica la dirección para las operaciones de reemplazo.
public enum FindReplaceDirection
Valores
Nombre | Valor | Descripción |
---|---|---|
Forward | 0 | Los elementos coincidentes se reemplazan del primero al último. |
Backward | 1 | Los elementos coincidentes se reemplazan desde el último al primero. |
Ejemplos
Muestra cómo determinar en qué dirección atraviesa el documento una operación de buscar y reemplazar.
public void Direction(FindReplaceDirection findReplaceDirection)
{
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
// Inserta tres ejecuciones que podamos buscar usando un patrón de expresiones regulares.
// Coloca una de esas ejecuciones dentro de un cuadro de texto.
builder.Writeln("Match 1.");
builder.Writeln("Match 2.");
builder.Writeln("Match 3.");
builder.Writeln("Match 4.");
// Podemos utilizar un objeto "FindReplaceOptions" para modificar el proceso de buscar y reemplazar.
FindReplaceOptions options = new FindReplaceOptions();
// Asigne una devolución de llamada personalizada a la propiedad "ReplacingCallback".
TextReplacementRecorder callback = new TextReplacementRecorder();
options.ReplacingCallback = callback;
// Establece la propiedad "Dirección" en "FindReplaceDirection.Backward" para obtener la búsqueda y el reemplazo
// operación para comenzar desde el final del rango y regresar al principio.
// Establece la propiedad "Dirección" en "FindReplaceDirection.Backward" para obtener la búsqueda y el reemplazo
// operación para comenzar desde el principio del rango y recorrer hasta el final.
options.Direction = findReplaceDirection;
doc.Range.Replace(new Regex(@"Match \d*"), "Replacement", options);
Assert.AreEqual("Replacement.\r" +
"Replacement.\r" +
"Replacement.\r" +
"Replacement.", doc.GetText().Trim());
switch (findReplaceDirection)
{
case FindReplaceDirection.Forward:
Assert.AreEqual(new[] { "Match 1", "Match 2", "Match 3", "Match 4" }, callback.Matches);
break;
case FindReplaceDirection.Backward:
Assert.AreEqual(new[] { "Match 4", "Match 3", "Match 2", "Match 1" }, callback.Matches);
break;
}
}
/// <summary>
/// Registra todas las coincidencias que ocurren durante una operación de buscar y reemplazar en el orden en que ocurren.
/// </summary>
private class TextReplacementRecorder : IReplacingCallback
{
ReplaceAction IReplacingCallback.Replacing(ReplacingArgs e)
{
Matches.Add(e.Match.Value);
return ReplaceAction.Replace;
}
public List<string> Matches { get; } = new List<string>();
}
Ver también
- espacio de nombres Aspose.Words.Replacing
- asamblea Aspose.Words