FindReplaceDirection
Innehåll
[
Dölj
]FindReplaceDirection enumeration
Anger riktning för ersättningsoperationer.
public enum FindReplaceDirection
Värderingar
namn | Värde | Beskrivning |
---|---|---|
Forward | 0 | Matchade objekt ersätts från första till sista. |
Backward | 1 | Matchade objekt ersätts från sista tillbaka till första. |
Exempel
Visar hur man bestämmer i vilken riktning en sök-och-ersätt-operation korsar dokumentet.
public void Direction(FindReplaceDirection findReplaceDirection)
{
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
// Infoga tre körningar som vi kan söka efter med hjälp av ett regexmönster.
// Placera en av dessa körningar i en textruta.
builder.Writeln("Match 1.");
builder.Writeln("Match 2.");
builder.Writeln("Match 3.");
builder.Writeln("Match 4.");
// Vi kan använda ett "FindReplaceOptions"-objekt för att ändra sök-och-ersätt-processen.
FindReplaceOptions options = new FindReplaceOptions();
// Tilldela en anpassad återuppringning till egenskapen "ReplacingCallback".
TextReplacementRecorder callback = new TextReplacementRecorder();
options.ReplacingCallback = callback;
// Ställ in "Direction"-egenskapen till "FindReplaceDirection.Backward" för att få sök-och-ersätt
// operation för att starta från slutet av intervallet och gå tillbaka till början.
// Ställ in "Direction"-egenskapen till "FindReplaceDirection.Backward" för att få sök-och-ersätt
// operation för att börja från början av intervallet och gå till slutet.
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>
/// Registrerar alla matchningar som inträffar under en sök-och-ersätt-operation i den ordning som de äger rum.
/// </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>();
}
Se även
- namnutrymme Aspose.Words.Replacing
- hopsättning Aspose.Words