2015-11-05 84 views
-1

我真的很沮喪..我真的需要顯示這張表的權利。如何設置這個代碼來顯示錶垂直這樣的:PHP表數據顯示結果垂直不水平

1 - 4 - 7

2 - 5 - 8

3 - 6 - 9

而且不喜歡這樣的:

1 - 2 - 3 - 4

5 - 6 - 7 - 8

9 - ... E ct

<?php 

$PNG_WEB_DIR = plugin_dir_path(__FILE__).'temp/'; 

wp_mkdir_p($PNG_WEB_DIR); 

$cols = $this->settings['cols']; 
$rows = $this->settings['rows']; 
$label_number = 0; 

// die($_GET['order_ids']); 
$order_ids = explode(',',$_GET['ids']); 
$order_count = count($order_ids); 
$labels_per_page = $cols*$rows; 
$page_count = ceil(($order_count)/$labels_per_page); 

for ($page=0; $page < $page_count; $page++) { 
    echo '<table class="address-labels" width="100%" height="100%" border="0" cellpadding="0">'; 
    $last_height = 0; 
    $current_height = $current_width = 0; 
    $current_row = 0; 

    for ($label=0; $label < $labels_per_page; $label++) { 
     $label_number++; 
     $current_col = (($label_number-1) % $cols)+1; 

     if ($current_col == 1) { 
      $last_height = $current_height; 
      $last_width = 0; 
      $current_row++; 
      echo '<tr class="label-row">'; 
     } 

     if ($label_number > $this->offset && isset($order_ids[$label_number - $this->offset - 1])) { 
      $order_id = $order_ids[$label_number - $this->offset - 1]; 
     } else { 
      $order_id = '';   
     } 

     $current_width = round($current_col * (100/$cols)); 
     $width = $current_width - $last_width; 
     $last_width = $current_width; 

     $current_height = round($current_row * (100/$rows)); 
     $height = $current_height - $last_height; 

     printf('<td width="%s%%" height="%s%%" class="label"><div class="label-wrapper">', $width, $height); 
     // because we are also looping through the empty labels, 
     // we need to check if there's an order for this label 
     if (!empty($order_id)) { 
      // get label data from order 
      $order = new WC_Order($order_id); 

      // replace placeholders 
      $label_data = isset($this->settings['address_data'])? nl2br($this->settings['address_data']): '[shipping_address]'; 
      $label_data = $this->make_replacements($label_data, $order); 

      echo '<div class="address-block">'; 
      echo '<div class="addrress_show">'; 

      // process label template to display content 
      echo $label_data; 
      echo '</div>'; 
      echo '<div class="clearb"></div>'; 
      echo '</div>'; 
     } else { 
      echo '&nbsp;'; 
     } 
     echo '</div></td>'; 

     if ($current_col == $cols) { 
      echo '</tr>'; 
     } 

    } 
    echo '</table>'; 
} 
     // shpt_after_page hook 
       do_action('shpt_after_page'); 
     ?> 
+1

什麼是原始數據結構?一個數組數組 - 即:多維數組? – RamRaider

+0

這是一個免費的WordPress插件的一部分https://wordpress.org/plugins/woocommerce-order-address-print/ 我希望它可以幫助你的問題,我是新的... –

+1

不,這並沒有真正的幫助 – RamRaider

回答

0

因爲我不知道你通過它使用循環和生產表的原始數據結構,我認爲它作爲一維數組,你要打印的表作爲3如你列說,在行動中看到這裏有一個PHP Fiddle - 命中運行時執行它 - 這對於任何數組長度工作,只要列是3,行是動態

PHP:更新了命名目的

<?php 
    $table = '<table class="address-labels" width="30%" border="0" cellpadding="0">'; 
    $dataArr = array(1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16, 17); 
    $colNum = 3; 
    $rowNum = ceil(count($dataArr)/$colNum); 
    for($i=0; $i < $rowNum; $i++){ 
     $x1 = isset($dataArr[$i]) ? $dataArr[$i] : '-'; 
     $x2 = isset($dataArr[$i + $rowNum]) ? $dataArr[$i + $rowNum] : '-'; 
     $x3 = isset($dataArr[$i + 2 * $rowNum]) ? $dataArr[$i + 2 * $rowNum] : '-'; 
     $table .= '<tr><td>' . $x1 . '</td><td>' . $x2 . '</td><td>' . $x3 . '</td></tr>'; 
    } 
    $table .= '</table>'; 
    echo $table; 

?> 

編輯: 現在,如果你想改變列號,就像它設置爲5,例如,你需要做到以下幾點:

月1日 - 設置$colNum = 5; 2日 - 添加多個變量來保存喜歡的值,*考慮到它是5列:

$x4 = isset($dataArr[$i + 3 * $rowNum]) ? $dataArr[$i + 3 * $rowNum] : '-'; 
$x5 = isset($dataArr[$i + 4 * $rowNum]) ? $dataArr[$i + 4 * $rowNum] : '-'; 

,不要忘記增加乘法器* $rowNum

然後對每個要添加額外的列,你需要添加<td></td>,如:

'<td>' . $x4 . '</td><td>' . '</td><td>' . $x5 . '</td><td>' . '</td>' 

這裏的另一個PHP Fiddle表示對上述5列。

0

試試這個。這是一個在純PHP

<?php 

$cols = 3; 
$data = range(1,29); 


// classic 
$index = 1; 
foreach($data as $el) 
{ 
    echo $el.' '; if ($index % $cols ==0) echo '<br/>'; 
    $index++; 
} 

echo '<br/><br/>'; 

// special 
$rows = $cols ; 
$cols = floor(count($data)/$cols); 

for($row = 0 ; $row < $rows; $row++){ 

    for ($index = $row; $index < count($data); $index += $rows) 
    echo $data[$index].' '; 
    echo '<br/>'; 

}