3

我正在为 Sharepoint 编写一个小应用程序。我正在尝试从返回的字段中间提取一些文本:

var ows_MetaInfo="1;#Subject:SW|NameOfADocument
vti_parservers:SR|23.0.0.6421
ContentTypeID:SW|0x0101001DB26Cf25E4F31488B7333256A77D2CA
vti_cachedtitle:SR|NameOfADocument
vti_title:SR|ATitleOfADocument
_Author:SW:|TheNameOfOurCompany
_Category:SW|
ContentType:SW|Document
vti_author::SR|mrwienerdog
_Comments:SW|This is very much the string I need extracted
vti_categories:VW|
vtiapprovallevel:SR|
vti_modifiedby:SR|mrwienerdog
vti_assignedto:SR|
Keywords:SW|Project Name
ContentType _Comments"

所以......我想要返回的只是“这就是我需要提取的字符串”

我需要正则表达式和字符串替换吗?您将如何编写正则表达式?

4

3 回答 3

2

是的,您可以为此使用正则表达式(这是他们擅长的事情)。假设您总是想要在以“_Comments:SW|”开头的行中的管道 (|) 之后的字符串,以下是提取它的方法:

var matchresult = ows_MetaInfo.match(/^_Comments:SW\|(.*)$/m);
var comment = (matchresult==null) ? "" : matchresult[1];

请注意,String 对象的 .match() 方法返回一个数组。第一个(索引 0)元素将是整个匹配项(这里,整个匹配项是整行,因为我们用 ^ 和 $ 锚定它;请注意,在正则表达式之后添加“m”使其成为多行正则表达式,允许我们匹配多行输入中任何行的开始和结束),数组的其余部分是我们使用括号捕获的子匹配。上面我们已经捕获了您想要的行的一部分,因此它将出现在数组中的第二项(索引 1)中。

如果没有匹配(“_Comments:SW|”没有出现在 ows_MetaInfo 中),那么 .match() 将返回 null,这就是我们在提取评论之前对其进行测试的原因。

如果您需要针对其他场景调整正则表达式,请查看 Mozilla 开发网络上的正则表达式文档: https ://developer.mozilla.org/en/JavaScript/Guide/Regular_Expressions

于 2012-05-01T19:28:21.970 回答
1

您可以使用以下代码:

var match = ows_MetaInfo.match(/_Comments:SW\|([^\n]+)/);
if (match)
   document.writeln(match[1]);
于 2012-05-01T19:26:09.067 回答
1

我远不能胜任 RegEx,所以这是我的无 RegEx 解决方案。有关更多详细信息,请参阅评论。

var extractedText = ExtractText(ows_MetaInfo);

function ExtractText(arg) {
    // Use the pipe delimiter to turn the string into an array
    var aryValues = ows_MetaInfo.split("|");

    // Find the portion of the array that contains "vti_categories:VW"
    for (var i = 0; i < aryValues.length; i++) {
        if (aryValues[i].search("vti_categories:VW") != -1)
            return aryValues[i].replace("vti_categories:VW", "");
    }

    return null;
}​

这是一个要演示的工作小提琴

于 2012-05-01T19:27:11.207 回答