Word前面没有正则表达式

时间:2015-04-29 10:06:14

标签: java regex regex-lookarounds

这些问题很多,但它们都集中在几个角色上。

在文本文件中我有TXX和txx,我需要找到它们。但我也有Base64编码图片。

意思是我

  

“picture”:“/ 9j / 4AAQSkTXX ...

基本上TXXtxx可以在Base64编码的图片中随机出现。

我使用了以下正则表达式:

(?<!"picture":")(?:(\w|\/|\+)+)(TXX|txx)

我也意识到它应该改成:

(?<!"picture":")(?:(\d|\w|\/|\+|\=)+)(TXX|txx)

但它说我正在进行灾难性的回溯,即使没有(?:)(非捕获组),它仍然无效。基本上它只是不采取“图片”:“和第一个字符,并采取其他一切。

因为我不能使用像

这样的量词将正则表达式放在负面的后面
(?<!"picture":".+)TXX|txx

我应该如何形成正则表达式以便传递

"something-txx": "somerandomstring"
value not picture:  "some other stringtxxsome string"

但这不是

"picture":"txxl5l71JGwnxMXAmJGOt8ZPwN24JNgtZpYHPBQLTViqVatk4ZoZhY+husj7Pgv3ag4NmpJ4CBlXudzydA5c+5QecmgaPz9vLrSbzRa+tNns0GjUfD+NSa5ZHo9KRf2nCWLl7360x2Kx8zA6dquNqubjoElpVRo2Dq0GOmZ8HMycktxxH08veKg84OPlCZvdDqvNxkPhOB0sn5wly+vdgx1Di82KzMxMlAoJQZkSJdGjZ0+UrlCJi/Xysc5GCPETtxxgUAgEAieNoQQLygg/P8K8VLaFCVVez+/SfMmPo74sNyxGz+/0YI8QKBQCAQCP4DPG6MeLrZcQvihFar46L6govdPE69movlMhIPh0NYaRJTtu2e+FQWyPkqDSsLqker0fKJVR0Oe5ap1RqoWD+pfuo7hefhbVJcfA8VlK42ycudJlIlMd1iMrnakePok5BPDyoUSvnhBMsEs9XMQ+PYrDQRqwd0Oj2vh/eVleXj5OMF7BSqhq2YjEa2TQ83nNDrPeHp5YWQEmXg4+vPPeLzIoR4gUAgEAcvvgETxtCiBcI/ifY2Y2aA57eWu7lJBAIBAKBQCB4eP62EC/JYWmoPBnFeieRnGKnk7e3yWTiYjN5fZPYLId5kcV67sHtcLBt+vZG4VzIu93lVe8SqUmsdzpsrDz7jse2tZrs+O/kxc7z5oGE/PtB+XOWs7tCtpB4z9NIkGf9YU3JeSmb0yV422np5AI8eaTXX"

示例输入已开启: http://pastebin.com/5XJVNqGS (我知道自从到期后,pastebin很糟糕,但是当页面卡住时我遇到了粘贴大量文本的问题)

结果应该是:

  

Result1:“some-txx”:值

     

结果2:hereisTXX:“1235”

     

结果3:“GROUPDATA”:“{DATA1:sample,TXX-value:12312,DATA2:sample2}”

1 个答案:

答案 0 :(得分:1)

我相信你可以使用一个相当有用的Java&#34;在某种程度上&#34;可变宽度的后视:

(?<!"picture":"[^"]{0,10000})(?i:txx)

如果你有更长的Base64编码字符串,你可以调整10000值。

RegexPlanet

上进行测试

如果您有非常大的图像,请使用反向字符串技巧和反向正则表达式(前瞻可能是未定义的可变大小):

String rx = "(?i)\"[^\"]*\"\\s*:\\s*\"[^\"]*xxt[^\"]*\"(?![^\"]*\":\"erutcip\")";

示例Java program on Ideone

import java.util.regex.*;
class HelloWorld{

     public static void main(String []args){

     String str = "THE_HUIGE_STRING_THAT_CAUSED_Body is limited to 30000 characters;you entered 53501_ISSUE";
     str = new StringBuilder(str).reverse().toString();
     String rx = "\"?[^\"]*\"?\\s*\"?[^\"\\n\\r]*(?:xxt|XXT)[^\"\\n\\r]*(?![^\"]*\":\"erutcip\")";
     Pattern ptrn = Pattern.compile(rx);
     Matcher m = ptrn.matcher(str);
     while (m.find()) {
         System.out.println(new StringBuilder(m.group(0)).reverse().toString());
     }

     m = ptrn.matcher(new StringBuilder("\"something-txx\": \"somerandomstring\"").reverse().toString());
     while (m.find()) {
        System.out.println(new StringBuilder(m.group(0)).reverse().toString());
     }
  }
}