Direction
Contenu
[
Cacher
]FindReplaceOptions.Direction property
Sélectionne la direction de remplacement. La valeur par défaut estForward .
public FindReplaceDirection Direction { get; set; }
Exemples
Montre comment déterminer dans quelle direction une opération de recherche et de remplacement parcourt le document.
public void Direction(FindReplaceDirection findReplaceDirection)
{
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
// Insère trois exécutions que nous pouvons rechercher à l'aide d'un modèle regex.
// Placez l'une de ces exécutions dans une zone de texte.
builder.Writeln("Match 1.");
builder.Writeln("Match 2.");
builder.Writeln("Match 3.");
builder.Writeln("Match 4.");
// Nous pouvons utiliser un objet "FindReplaceOptions" pour modifier le processus de recherche et de remplacement.
FindReplaceOptions options = new FindReplaceOptions();
// Attribue un rappel personnalisé à la propriété "ReplacingCallback".
TextReplacementRecorder callback = new TextReplacementRecorder();
options.ReplacingCallback = callback;
// Définissez la propriété "Direction" sur "FindReplaceDirection.Backward" pour obtenir la recherche et le remplacement
// opération pour commencer à la fin de la plage et revenir au début.
// Définissez la propriété "Direction" sur "FindReplaceDirection.Backward" pour obtenir la recherche et le remplacement
// opération pour commencer au début de la plage et parcourir jusqu'à la fin.
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>
/// Enregistre toutes les correspondances qui se produisent lors d'une opération de recherche et de remplacement dans l'ordre dans lequel elles ont lieu.
/// </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>();
}
Voir également
- enum FindReplaceDirection
- class FindReplaceOptions
- espace de noms Aspose.Words.Replacing
- Assemblée Aspose.Words