Swing/GetLineText のバックアップの現在との差分(No.11)
- バックアップ一覧
- 差分 を表示
- 現在との差分 - Visual を表示
- ソース を表示
- バックアップ を表示
- Swing/GetLineText へ行く。
- 1 (2006-10-10 (火) 14:36:01)
- 2 (2006-11-06 (月) 13:06:59)
- 3 (2006-11-10 (金) 13:50:48)
- 4 (2007-05-07 (月) 13:55:23)
- 5 (2007-05-27 (日) 01:31:30)
- 6 (2007-06-04 (月) 15:08:35)
- 7 (2007-12-10 (月) 20:48:52)
- 8 (2012-02-09 (木) 12:16:59)
- 9 (2012-06-19 (火) 14:55:23)
- 10 (2013-02-22 (金) 19:02:46)
- 11 (2014-12-18 (木) 17:17:10)
- 12 (2015-10-15 (木) 00:18:22)
- 13 (2016-05-30 (月) 16:27:12)
- 14 (2016-09-17 (土) 20:53:53)
- 15 (2017-10-26 (木) 10:59:52)
- 16 (2019-04-11 (木) 13:24:20)
- 17 (2021-01-23 (土) 21:35:26)
- 18 (2023-07-07 (金) 13:57:47)
- 追加された行はこの色です。
- 削除された行はこの色です。
--- category: swing folder: GetLineText title: JTextAreaから一行ずつ文字列を取得 tags: [JTextArea, StringTokenizer, LineNumberReader] author: aterai pubdate: 2006-10-09 pubdate: 2006-10-09T22:13:19+09:00 description: JTextAreaなどのテキストコンポーネントから一行ずつ文字列を取り出してそれを処理します。 image: https://lh3.googleusercontent.com/_9Z4BYR88imo/TQTNWn74dWI/AAAAAAAAAao/pNdeF8CSOfM/s800/GetLineText.png --- * 概要 [#sce4576b] * 概要 [#summary] `JTextArea`などのテキストコンポーネントから一行ずつ文字列を取り出してそれを処理します。 #download(https://lh3.googleusercontent.com/_9Z4BYR88imo/TQTNWn74dWI/AAAAAAAAAao/pNdeF8CSOfM/s800/GetLineText.png) * サンプルコード [#cba0b2ee] * サンプルコード [#sourcecode] #code(link){{ int count = 0; StringTokenizer st = new StringTokenizer(textArea.getText(), "\n") ; while(st.hasMoreTokens()) { if(st.nextToken().startsWith("#")) { StringTokenizer st = new StringTokenizer(textArea.getText(), "\n"); while (st.hasMoreTokens()) { if (st.nextToken().codePointAt(0) == '#') { count++; } } }} * 解説 [#v1446cab] 上記のサンプルでは、`JTextArea#getText()`ですべてのテキストを取得し、`StringTokenizer`を使って行毎に分解しています。 * 解説 [#explanation] 上記のサンプルでは、`JTextArea#getText()`ですべてのテキストを取得してから`StringTokenizer`を使って行毎に分解しています。`returnDelims`フラグが`false`なのでトークンが空行になることはありません。 ---- - `String#split`を使用する場合 - `String#split(...)`を使用する場合 -- 空行あり #code{{ for(String line: textArea.getText().split("\\n")) { if(line.startsWith("#")) { for (String line: textArea.getText().split("\\n")) { if (!line.isEmpty() && line.codePointAt(0) == '#') { count++; } } }} - `LineNumberReader`を使用する場合 -- 空行あり #code{{ try(LineNumberReader lnr = new LineNumberReader(new StringReader(textArea.getText()))) { try (LineNumberReader lnr = new LineNumberReader(new StringReader(txa.getText()))) { String line = null; while((line = lnr.readLine()) != null) { if(line.startsWith("#")) { while ((line = lnr.readLine()) != null) { if (!line.isEmpty() && line.codePointAt(0) == '#') { count++; } } }catch(IOException ioe) { } catch (IOException ioe) { ioe.printStackTrace(); } }} - `Element#getElementCount`を使用する場合 - `Element#getElementCount()`を使用する場合 -- 空行なし(`Element`には少なくとも長さ`1`の改行が存在する) #code{{ 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.startsWith("#")) { try { for (int i = 0; i < root.getElementCount(); i++) { Element elm = root.getElement(i); String line = doc.getText( elm.getStartOffset(), elm.getEndOffset() - elm.getStartOffset()); if (line.codePointAt(0) == '#') { count++; } } }catch(BadLocationException ble) { } catch (BadLocationException ble) { ble.printStackTrace(); } }} //* 参考リンク * コメント [#ee4fa454] * 参考リンク [#reference] - [https://docs.oracle.com/javase/jp/8/docs/api/java/util/StringTokenizer.html StringTokenizer (Java Platform SE 8)] - [https://docs.oracle.com/javase/jp/8/docs/api/java/io/LineNumberReader.html LineNumberReader (Java Platform SE 8)] - [https://docs.oracle.com/javase/jp/8/docs/api/javax/swing/text/Element.html#getElementCount-- Element#getElementCount() (Java Platform SE 8)] * コメント [#comment] #comment #comment