Regex Отклонение матчей из-за Instr - PullRequest
3 голосов
/ 13 августа 2008

Какой самый простой способ сделать функцию типа "instring" с помощью регулярного выражения? Например, как я могу отклонить целую строку из-за присутствия одного символа, такого как :? Например:

  • this - хорошо
  • there:is - не в порядке из-за :

Практически, как мне найти следующую строку:

//foo/bar/baz[1]/ns:foo2/@attr/text()

Для любого теста узла в xpath, который не включает пространство имен?

(/)?(/)([^:/]+) 

Будет соответствовать тестам узла, но содержит префикс пространства имен, что делает его неисправным.

Ответы [ 5 ]

2 голосов
/ 14 августа 2008

Я до сих пор не уверен, хотите ли вы просто определить, содержит ли Xpath пространство имен или вы хотите удалить ссылки на пространство имен. Итак, вот пример кода (в C #), который делает и то, и другое.

class Program
{
    static void Main(string[] args)
    {
        string withNamespace = @"//foo/ns2:bar/baz[1]/ns:foo2/@attr/text()";
        string withoutNamespace = @"//foo/bar/baz[1]/foo2/@attr/text()";

        ShowStuff(withNamespace);
        ShowStuff(withoutNamespace);
    }

    static void ShowStuff(string input)
    {
        Console.WriteLine("'{0}' does {1}contain namespaces", input, ContainsNamespace(input) ? "" : "not ");
        Console.WriteLine("'{0}' without namespaces is '{1}'", input, StripNamespaces(input));
    }

    static bool ContainsNamespace(string input)
    {
        // a namspace must start with a character, but can have characters and numbers
        // from that point on.
        return Regex.IsMatch(input, @"/?\w[\w\d]+:\w[\w\d]+/?");
    }

    static string StripNamespaces(string input)
    {
        return Regex.Replace(input, @"(/?)\w[\w\d]+:(\w[\w\d]+)(/?)", "$1$2$3");
    }
}

Надеюсь, это поможет! Удачи.

1 голос
/ 13 августа 2008

Матч по:? Я думаю, что вопрос недостаточно ясен, потому что ответ так очевиден:

if(Regex.Match(":", input)) // reject
0 голосов
/ 14 августа 2008

Да, мой вопрос был не очень ясен. Вот решение, но вместо одного прохода с регулярным выражением я использую split и выполняю итерацию. Это работает так же хорошо, но не так элегантно:

string xpath = "//foo/bar/baz[1]/ns:foo2/@attr/text()";
string[] nodetests = xpath.Split( new char[] { '/' } );
for (int i = 0; i < nodetests.Length; i++) 
{
    if (nodetests[i].Length > 0 && Regex.IsMatch( nodetests[i], @"^(\w|\[|\])+$" ))
    {
        // does not have a ":", we can manipulate it.
    }
}

xpath = String.Join( "/", nodetests );
0 голосов
/ 13 августа 2008

Возможно, вы захотите \ w, который является символом «слова». Начиная с javadocs , он определяется как [a-zA-Z_0-9], поэтому, если вам не нужны подчеркивания, это может не сработать ....

0 голосов
/ 13 августа 2008

Я не очень хорошо знаю синтаксис регулярных выражений, но не могли бы вы:

[any alpha numeric]\*:[any alphanumeric]\*

Я думаю, что-то подобное должно работать, нет?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...