3

我有一个可以作为文本框读取的文件,我想只获取之后可用的数据

开始="n= 和结束="n=

 <?xml version="1.0" encoding="utf-8"?>
 <!DOCTYPE smil PUBLIC "-//W3C//DTD SMIL 1.0//EN" "SMIL10.dtd">
 <head>
 </head>
     <body>
            <audio start="n=10.815s" end="n=19.914s"/>
 </body>
</xml>

我尝试执行以下操作:

   String startTime = readString.replaceAll(".*start=\"n=|\\s.*", "").trim();
   String endTime = readString.replaceAll(".*end=\"n=|\\s.*", "").trim();
   Log.e("Start Time is :" , startTime);
   Log.e("endTime Time is :" , endTime);

它工作正常,只需获取开始时间和结束时间,但它也显示<?xml标签。

我该如何解决?

4

4 回答 4

3

我宁愿使用 XML 解析器来阅读它。正则表达式不适合解析 XML/HTML 等。您会在 SO 中找到许多与 this 相关的参考资料。

对于 Java,DOM 和 SAX 是可能的,但JDOM可能是一个更容易的起点。

于 2012-12-17T10:45:39.470 回答
2

请在 Java 中找到下面的解决方案,这适用于任何包含字符串的数据

<audio start="n=........" end="n=......." />

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class Test {
public static void main(String[] args) 
{
String inputData1 = "<?xml version=\"1.0\" encoding=\"utf-8\"?>"+
                        "<!DOCTYPE smil PUBLIC \"-//W3C//DTD SMIL 1.0//EN\" \"SMIL10.dtd\">"
                        + "<head>" 
                        + "</head>" 
                        + "<body>"
                        + "<audio start=\"n=10.815s\" end=\"n=19.914s\"/>"
                        + "<sometag> <audio start=\"n=10.815s\" end=\"n=20.914s\"/> </sometag>"
                        + "</body>"
                        + "</xml>";

    String inputData2 = "some data goes here with or without tags; <audio start=\"n=10.815s\" end=\"n=20.914s\"/>; askjdhfla ";

    Pattern pattern = Pattern.compile("<audio[^>]*start\\s*=\\s*\"n\\s*=\\s*([^\"]*)\"[^>]*end=\"n\\s*=\\s*([^\"]*)\"[^>]*>");
    Matcher matcher = pattern.matcher(inputData1);

    while(matcher.find()){
        System.out.println("start=\"n="+matcher.group(1)+", & end=\"n="+matcher.group(2)+"");
    }

}
}

Output For InputData1:
start="n=10.815s, & end="n=19.914s
start="n=10.815s, & end="n=20.914s


Output For InputData2:
start="n=10.815s, & end="n=20.914s
于 2012-12-17T14:32:51.723 回答
1

它始终是通过解析器而不是正则表达式解析 xml/html 的最佳方式。但是关于你的问题。您可以尝试以下操作:

String s = "foo\n <audio start=\"n=10.815s\" end=\"n=19.914s\"/>bar\n";
String re = "(?s).*?(?<=start=\"n=)([^\"]*).*";
String startTime=s.replaceAll(re, "$1");

上面的例子会给String 10.815sstartTime。如果要获取 endTime,请将 re (start) 替换为 (end)

关于正则表达式的简短说明:

(?s) is flag dotall, which means, the regex will match new lines as well
(?<=start=\"n=)([^\"]*) this is look behind. 
                        search for text following start="n=
                        and not "(double quote) in this case is 10.815s

希望能帮助到你

于 2012-12-17T11:09:41.547 回答
1

我正在加入以前的答案。但是如果你的文件总是很小,只有几个字符串,你可以使用正则表达式。在这种情况下,试试这个模式:(\n|\r|.)*end\s*=\s*\"n=(.*)\"(\n|\r|.)*"

UPD:第 2 组将完全满足您的需求。

于 2012-12-17T10:51:31.203 回答