当前位置: 首页>>代码示例>>PHP>>正文


PHP DataTable::setRows方法代码示例

本文整理汇总了PHP中Piwik\DataTable::setRows方法的典型用法代码示例。如果您正苦于以下问题:PHP DataTable::setRows方法的具体用法?PHP DataTable::setRows怎么用?PHP DataTable::setRows使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Piwik\DataTable的用法示例。


在下文中一共展示了DataTable::setRows方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: sort

 /**
  * Sorts the DataTable rows using the supplied callback function.
  *
  * @param DataTable $table The table to sort.
  */
 public function sort(DataTable $table)
 {
     // all that code is in here and not in separate methods for best performance. It does make a difference once
     // php has to copy many (eg 50k) rows otherwise.
     $table->setTableSortedBy($this->config->primaryColumnToSort);
     $rows = $table->getRowsWithoutSummaryRow();
     // we need to sort rows that have a value separately from rows that do not have a value since we always want
     // to append rows that do not have a value at the end.
     $rowsWithValues = array();
     $rowsWithoutValues = array();
     $valuesToSort = array();
     foreach ($rows as $key => $row) {
         $value = $this->getColumnValue($row);
         if (isset($value)) {
             $valuesToSort[] = $value;
             $rowsWithValues[] = $row;
         } else {
             $rowsWithoutValues[] = $row;
         }
     }
     unset($rows);
     if ($this->config->isSecondaryColumnSortEnabled && $this->config->secondaryColumnToSort) {
         $secondaryValues = array();
         foreach ($rowsWithValues as $key => $row) {
             $secondaryValues[$key] = $row->getColumn($this->config->secondaryColumnToSort);
         }
         array_multisort($valuesToSort, $this->config->primarySortOrder, $this->config->primarySortFlags, $secondaryValues, $this->config->secondarySortOrder, $this->config->secondarySortFlags, $rowsWithValues);
     } else {
         array_multisort($valuesToSort, $this->config->primarySortOrder, $this->config->primarySortFlags, $rowsWithValues);
     }
     if (!empty($rowsWithoutValues) && $this->config->secondaryColumnToSort) {
         $secondaryValues = array();
         foreach ($rowsWithoutValues as $key => $row) {
             $secondaryValues[$key] = $row->getColumn($this->config->secondaryColumnToSort);
         }
         array_multisort($secondaryValues, $this->config->secondarySortOrder, $this->config->secondarySortFlags, $rowsWithoutValues);
     }
     unset($secondaryValues);
     foreach ($rowsWithoutValues as $row) {
         $rowsWithValues[] = $row;
     }
     $table->setRows(array_values($rowsWithValues));
 }
开发者ID:piwik,项目名称:piwik,代码行数:48,代码来源:Sorter.php

示例2: sort

 /**
  * Sorts the DataTable rows using the supplied callback function.
  *
  * @param string $functionCallback A comparison callback compatible with {@link usort}.
  * @param string $columnSortedBy The column name `$functionCallback` sorts by. This is stored
  *                               so we can determine how the DataTable was sorted in the future.
  */
 private function sort(DataTable $table, $functionCallback)
 {
     $table->setTableSortedBy($this->columnToSort);
     $rows = $table->getRowsWithoutSummaryRow();
     // get column value and label only once for performance tweak
     $values = array();
     if ($functionCallback === 'numberSort') {
         foreach ($rows as $key => $row) {
             $values[$key] = array($this->getColumnValue($row), $row->getColumn('label'));
         }
     } else {
         foreach ($rows as $key => $row) {
             $values[$key] = $this->getColumnValue($row);
         }
     }
     uasort($values, array($this, $functionCallback));
     $sortedRows = array();
     foreach ($values as $key => $value) {
         $sortedRows[] = $rows[$key];
     }
     $table->setRows($sortedRows);
     unset($rows);
     unset($sortedRows);
     if ($table->isSortRecursiveEnabled()) {
         foreach ($table->getRowsWithoutSummaryRow() as $row) {
             $subTable = $row->getSubtable();
             if ($subTable) {
                 $subTable->enableRecursiveSort();
                 $this->sort($subTable, $functionCallback);
             }
         }
     }
 }
开发者ID:bossrabbit,项目名称:piwik,代码行数:40,代码来源:Sort.php

示例3: filter

 /**
  * @param DataTable $table
  */
 public function filter($table)
 {
     $numRows = 0;
     $lastGroupFromPreviousPage = null;
     foreach ($table->getRows() as $row) {
         $this->addRowIfNeeded($row, $numRows);
         $numRows++;
         $subtable = $row->getSubtable();
         if ($subtable) {
             if (!$this->hasRows()) {
                 $lastGroupFromPreviousPage = $row;
             }
             foreach ($subtable->getRows() as $subRow) {
                 $this->addRowIfNeeded($subRow, $numRows);
                 $numRows++;
             }
             $row->removeSubtable();
         }
         if ($this->hasNumberOfRequestedRowsFound()) {
             break;
         }
     }
     $this->prependGroupIfFirstSiteBelongsToAGroupButGroupIsMissingInRows($lastGroupFromPreviousPage);
     $table->setRows($this->rows);
 }
开发者ID:FluentDevelopment,项目名称:piwik,代码行数:28,代码来源:NestedSitesLimiter.php


注:本文中的Piwik\DataTable::setRows方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。