Zend_Text_Table.xml 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 17178 -->
  4. <sect1 id="zend.text.table.introduction">
  5. <title>Zend_Text_Table</title>
  6. <para>
  7. <classname>Zend_Text_Table</classname> は、さまざまなデコレータを使用して
  8. テキストベースの表をその場で作成するためのコンポーネントです。
  9. これは、たとえばテキスト形式のメールで構造化されたデータを送信したい場合などに便利です。
  10. その場合は等幅フォントを使う必要があります。
  11. また、CLI アプリケーションで表形式の情報を表示する場合にも便利です。
  12. <classname>Zend_Text_Table</classname> は、複数行にわたるカラムやカラムの連結、
  13. テキストの配置の指定に対応しています。
  14. </para>
  15. <note>
  16. <title>エンコーディング</title>
  17. <para>
  18. <classname>Zend_Text_Table</classname> のデフォルトでは、文字列が
  19. UTF-8 でエンコードされていることを前提としています。
  20. もしそれ以外を使用している場合は、文字エンコーディングを
  21. コンストラクタあるいは <classname>Zend_Text_Table_Column</classname>
  22. の <code>setContent</code> メソッドのパラメータで指定します。
  23. もうひとつの方法として、もしそのエンコーディングをプロセス全体で使う場合には
  24. <methodname>Zend_Text_Table::setInputCharset($charset)</methodname>
  25. で標準の入力文字セットを定義することができます。
  26. 表を出力する際に別の文字セットを使用したい場合は、
  27. <methodname>Zend_Text_Table::setOutputCharset($charset)</methodname> で設定します。
  28. </para>
  29. </note>
  30. <para>
  31. <classname>Zend_Text_Table</classname> オブジェクトは行の集まりで構成されており、
  32. 行は列の集まりで構成されています。行と列を表すのが、それぞれ
  33. <classname>Zend_Text_Table_Row</classname> および
  34. <classname>Zend_Text_Table_Column</classname> です。
  35. 表を作成する際に、表のオプションを配列で指定することができます。
  36. 指定できるオプションは次のとおりです。
  37. <itemizedlist>
  38. <listitem>
  39. <para>
  40. <code>columnWidths</code> (必須):
  41. 配列で、すべてのカラムとその幅 (文字数) を指定します。
  42. </para>
  43. </listitem>
  44. <listitem>
  45. <para>
  46. <code>decorator</code>: テーブルの罫線に使用するデコレータ。
  47. デフォルトは <code>unicode</code> ですが、<code>ascii</code>
  48. あるいは独自のデコレータオブジェクトのインスタンスを指定することもできます。
  49. </para>
  50. </listitem>
  51. <listitem>
  52. <para>
  53. <code>padding</code>: カラムの左右の余白文字数。
  54. デフォルトはゼロです。
  55. </para>
  56. </listitem>
  57. <listitem>
  58. <para>
  59. <code>AutoSeparate</code>: 各行を横線でどのように区切るかの方法。
  60. デフォルトは、すべての行間を区切ります。これは、次の
  61. <classname>Zend_Text_Table</classname> の定数のビットマスクで指定します。
  62. <itemizedlist>
  63. <listitem>
  64. <para><constant>Zend_Text_Table::AUTO_SEPARATE_NONE</constant></para>
  65. </listitem>
  66. <listitem>
  67. <para><constant>Zend_Text_Table::AUTO_SEPARATE_HEADER</constant></para>
  68. </listitem>
  69. <listitem>
  70. <para><constant>Zend_Text_Table::AUTO_SEPARATE_FOOTER</constant></para>
  71. </listitem>
  72. <listitem>
  73. <para><constant>Zend_Text_Table::AUTO_SEPARATE_ALL</constant></para>
  74. </listitem>
  75. </itemizedlist>
  76. ヘッダは常に最初の行、フッタは常に最後の行となります。
  77. </para>
  78. </listitem>
  79. </itemizedlist>
  80. </para>
  81. <para>
  82. 表に行を追加するには、
  83. <classname>Zend_Text_Table_Row</classname> のインスタンスを作成して、それを
  84. <code>appendRow</code> メソッドで追加します。行自体には何もオプションはありません。
  85. 配列を直接 <code>appendRow</code> メソッドに渡すこともできます。
  86. この場合は、複数の列オブジェクトからなる行オブジェクトに自動的に変換されます。
  87. </para>
  88. <para>
  89. 行に列を追加する方法も同じです。
  90. <classname>Zend_Text_Table_Column</classname> のインスタンスを作成し、
  91. 列のオプションをコンストラクタで指定するか、あるいは後から
  92. <code>set*</code> メソッドで設定します。
  93. 最初のパラメータは列の中身で、これは複数行にすることもできます。
  94. 複数行にする場合は <code>\n</code> で行を区切ります。
  95. 2 番目のパラメータは配置を指定します。デフォルトは左詰めで、
  96. <classname>Zend_Text_Table_Column</classname> のクラス定数のいずれかを指定することができます。
  97. <itemizedlist>
  98. <listitem>
  99. <para>
  100. <constant>ALIGN_LEFT</constant>
  101. </para>
  102. </listitem>
  103. <listitem>
  104. <para>
  105. <constant>ALIGN_CENTER</constant>
  106. </para>
  107. </listitem>
  108. <listitem>
  109. <para>
  110. <constant>ALIGN_RIGHT</constant>
  111. </para>
  112. </listitem>
  113. </itemizedlist>
  114. 3 番目のパラメータは列の連結 (colspan) を指定します。
  115. たとえば、このパラメータに "2" を指定すると、
  116. 表の中で 2 つの列が連結されるようになります。
  117. 最後のパラメータは列の中身のエンコーディングです。
  118. ASCII および UTF-8 以外を使用する場合は必ず指定しなければなりません。
  119. 行を列に追加するには、行オブジェクトの <code>appendColumn</code>
  120. のパラメータに列オブジェクトを指定してコールします。
  121. あるいは、文字列を直接 <code>appendColumn</code> メソッドに渡すこともできます。
  122. </para>
  123. <para>
  124. 最後に、表をレンダリングするには <code>render</code>
  125. メソッドを使用します。あるいは、
  126. <code>echo $table;</code> や <code>$tableString = (string) $table</code>
  127. などとしてマジックメソッド <code>__toString</code> を使用することもできます。
  128. </para>
  129. <example id="zend.text.table.example.using">
  130. <title>Zend_Text_Table の使用例</title>
  131. <para>
  132. この例では、<classname>Zend_Text_Table</classname>
  133. でシンプルな表を作成するための方法を示します。
  134. </para>
  135. <programlisting language="php"><![CDATA[
  136. $table = new Zend_Text_Table(array('columnWidths' => array(10, 20)));
  137. // シンプルな例
  138. $table->appendRow(array('Zend', 'Framework'));
  139. // あるいは冗長な例
  140. $row = new Zend_Text_Table_Row();
  141. $row->appendColumn(new Zend_Text_Table_Column('Zend'));
  142. $row->appendColumn(new Zend_Text_Table_Column('Framework'));
  143. $table->appendRow($row);
  144. echo $table;
  145. ]]></programlisting>
  146. <para>
  147. この結果は次のようになります。
  148. </para>
  149. <programlisting language="text"><![CDATA[
  150. ┌──────────┬────────────────────┐
  151. │Zend │Framework │
  152. └──────────┴────────────────────┘
  153. ]]></programlisting>
  154. </example>
  155. </sect1>
  156. <!--
  157. vim:se ts=4 sw=4 et:
  158. -->