我如何计算这些值?

时间:2011-11-27 09:50:55

标签: java string

我有一个DB,通常生成一个3000行的文件,实际上我想计算LAYERID的数量

我的数据库文件是这样的:

CREATE TRMD=GFT,LAYID=LY_00,USFGN=DISABLED;
CREATE BUTYP=ACB8T,RAAT=FALSE,GBPATH=AAP4,GTXT=12;
CREATE TRMD=GFT,LAYID=LY_00,USFGN=DISABLED;
CREATE TRMD=GFT,LAYID=LY_01,USFGN=DISABLED;
CREATE TRMD=GFT,LAYID=LY_01,USFGN=DISABLED;
CREATE TRMD=GFT,LAYID=LY_02,USFGN=DISABLED;
CREATE BUTYP=ACB9T,RAAT=TRUE,GBPATH=AAP4,GTXT=32;
CREATE TRMD=GFT,LAYID=LY_00,USFGN=DISABLED;
CREATE TRMD=GFT,LAYID=LY_01,USFGN=DISABLED;
CREATE TRMD=GFT,LAYID=LY_02,USFGN=DISABLED;
CREATE TRMD=GFT,LAYID=LY_03,USFGN=DISABLED;
CREATE TRMD=GFT,LAYID=LY_03,USFGN=DISABLED;
CREATE BUTYP=ACB2T,RAAT=TRUE,GBPATH=AAP4,GTXT=1;
CREATE TRMD=GFT,LAYID=LY_00,USFGN=DISABLED;
CREATE BUTYP=ACB8T,RAAT=FALSE,GBPATH=AAP4,GTXT=2;
CREATE TRMD=GFT,LAYID=LY_00,USFGN=DISABLED;
CREATE BUTYP=ACB8T,RAAT=TRUE,GBPATH=AAP4,GTXT=3;

如果我们只有“LAYID=LY_00”(就像第一行一样),我们必须忽略它,但如果在“LAYID=LY_00”下面是“LAYID=LY_01和......”(如第三行)我们必须计算“LAYID=LY_00”和其他图层,例如在第3行到第6行我们有4个Layeids

LAYID=LY_00
LAYID=LY_01
LAYID=LY_01
LAYID=LY_02

所以数量为4,如果我们想要计算所有这些数量,我们有9个,如前所述,如果我们只有

LAYID = LY_00 simillar line 1我们忽略它。

我也写了这个方法逐行阅读:

public void execToken(File f) throws Exception {
        BufferedReader br = new BufferedReader(new FileReader(f));
        String line;
        while ((line = br.readLine()) != null) {
            StringTokenizer strt = new StringTokenizer(line, ";");
            while (strt.hasMoreTokens()) {
                String token = strt.nextToken();
                layerSupport(token);
            }
        }
    }

并且,我知道下面的方法不是真的和完整的,但它可能对你有用

public void layerSupport(String token){
        if(token.startsWith("CREATE TRMD") && !token.contains("LAYID=LY_00"))
            System.out.println(token) ;

    }   
非常感谢你的帮助......

2 个答案:

答案 0 :(得分:1)

类似的东西:

public int execToken(File f) throws Exception {
    BufferedReader br = new BufferedReader(new FileReader(f));
    int count = 0;
    String line;
    String previousLine = ""; 
    while ((line = br.readLine()) != null) {
        if (line.startsWith("CREATE TRMD")) {
            if (!previousLine.isEmpty()) {
                count += (previousLine.contains("LAYID=LY_00") ? 2 : 1);
            }
            previousLine = line;
        } else {
            previousLine = "";
        }
    }

    return count;
}

未经测试。

答案 1 :(得分:1)

public int execToken(File f) throws Exception
{
    BufferedReader br = new BufferedReader(new FileReader(f));
    String line;
    int count = 0;
    Pattern layID = Pattern.compile("LAYID=LY_\\d+");
    Matcher matcher = null;
    boolean isSingle = true;
    while ((line = br.readLine()) != null)
    {
        if(line.contains("LAYID=LY_00"))
        {
            isSingle = false;
            continue;
        }
        matcher = layID.matcher(line);
        if(matcher.find())
        {
            count++;
            if(!isSingle)
                count++;
        }

        isSingle = true;
    }
    return count;
}

尝试this.it会记住前一行是否包含LAYID=LY_00并且在下一次迭代中增量计数两次,如果找到LAYID=LY_<digits>并且isSingle为false。