• category: swing folder: GetLineText title: JTextAreaから一行ずつ文字列を取得 tags: [JTextArea, StringTokenizer, LineNumberReader] author: aterai pubdate: 2006-10-09 description: JTextAreaなどのテキストコンポーネントから一行ずつ文字列を取り出してそれを処理します。 image: https://lh3.googleusercontent.com/_9Z4BYR88imo/TQTNWn74dWI/AAAAAAAAAao/pNdeF8CSOfM/s800/GetLineText.png

概要

JTextAreaなどのテキストコンポーネントから一行ずつ文字列を取り出してそれを処理します。

サンプルコード

int count = 0;
StringTokenizer st = new StringTokenizer(textArea.getText(), "\n");
while (st.hasMoreTokens()) {
  if (st.nextToken().codePointAt(0) == '#') {
    count++;
  }
}
View in GitHub: Java, Kotlin

解説

上記のサンプルでは、JTextArea#getText()ですべてのテキストを取得し、StringTokenizerを使って行毎に分解しています。returnDelimsフラグがfalseなので、トークンが空行になることはありません。


  • String#split(...)を使用する場合
    • 空行あり
for (String line: textArea.getText().split("\\n")) {
  if (!line.isEmpty() && line.codePointAt(0) == '#') {
    count++;
  }
}
  • LineNumberReaderを使用する場合
    • 空行あり
try (LineNumberReader lnr = new LineNumberReader(new StringReader(textArea.getText()))) {
  String line = null;
  while ((line = lnr.readLine()) != null) {
    if (!line.isEmpty() && line.codePointAt(0) == '#') {
      count++;
    }
  }
} catch (IOException ioe) {
  ioe.printStackTrace();
}
  • Element#getElementCount()を使用する場合
    • 空行なし(Elementには少なくとも長さ1の改行が存在する)
Document doc = textArea.getDocument();
Element root = doc.getDefaultRootElement();
try {
  for (int i = 0; i < root.getElementCount(); i++) {
    Element elem = root.getElement(i);
    String line = doc.getText(elem.getStartOffset(), elem.getEndOffset() - elem.getStartOffset());
    if (line.codePointAt(0) == '#') {
      count++;
    }
  }
} catch (BadLocationException ble) {
  ble.printStackTrace();
}

コメント