2

我必须从 .txt 文件中分离出一个值。我创建了一个 LineNumberReader 并使用 .split("\t") 来分隔单词,但我只需要倒数第二个值(q-value)。是否有指定 .split() 的选项?

这是我的 .txt 文件

test_id gene_id gene    locus   sample_1    sample_2    status  value_1 value_2 log2(fold_change)   test_stat   p_value q_value significant
XLOC_000001 XLOC_000001 TC012951    ChLG10:20399-27664  naive   BttO    NOTEST  0   0.0498691   1.79769e+308    1.79769e+308    0.210754    1   no
4

3 回答 3

1
String[] array = someString.split("\t");
String secondToLast = array[array.length - 2];
于 2013-02-06T14:27:36.323 回答
1

您可以使用该String#split(String regex, int limit)方法在要提取的列之后停止拆分,并在一行代码中获取所需的字符串:

    String line = "A\tB\tC\tD\tE\tF"; // tab separated content
    int column = 3; // specify the column you want (first is 1)
    String content = line.split("\t", column + 1)[column - 1]; // get content 
    System.out.println(content);  // prints C (3rd column)
于 2013-02-06T14:31:31.777 回答
0

鉴于您有这一行:

XLOC_000001 XLOC_000001 TC012951    ChLG10:20399-27664  naive   BttO    NOTEST  0   0.0498691   1.79769e+308    1.79769e+308    0.210754    1   no

你想要1(倒数第二个元素)

你可以使用这个表达式:

String s ="XLOC_000001 XLOC_000001 TC012951\tChLG10:20399-27664\tnaive\tBttO\tNOTEST\t0\t0.0498691\t1.79769e+308\t1.79769e+308\t0.210754\t1\tno";
Matcher m = Pattern.compile("(?:\t|^)([^\t]*?)\t[^\t]*?(?:\\n|$)").matcher(s);
if(m.find())
    System.out.println(m.group(1));

或者,包装在一个函数中:

private static final Pattern pattern = Pattern.compile("(?:\t|^)([^\t]*?)\t[^\t]*?(?:\\n|$)");
public static final String getPenultimateElement(String line) {
    Matcher m = pattern.matcher(line);
    if(m.find())
        return m.group(1)
    return null; // or throw exception.
}

或者,调用者可以指定分隔符:

public static final String getPenultimateElement(String line, String separator) {
    separator = Pattern.quote(separator);
    Matcher m = Pattern.compile("(?:" separator + "|^)([^" + separator + "]*?)" + separator + "[^" + separator + "]*?(?:\\n|$)").matcher(line);
    if(m.find())
        return m.group(1)
    return null; // or throw exception.
}
于 2013-02-06T14:34:48.157 回答