gpt4 book ai didi

php - 在保持表格结构的同时垂直显示表格值

转载 作者:可可西里 更新时间:2023-11-01 13:26:29 24 4
gpt4 key购买 nike

一直在检查用于对数组值进行<​​strong>垂直排序以便在表格中使用的其他方法,但其中大多数方法相当于将表格向右翻转 90 度。我一直在想办法正确地实现它,但我认为我需要一些帮助。

例如表格(横排):

a  b  c  d  e
f g h i j
k l m n o
p q r

重新排序为(垂直顺序):

a  e  i  m  p
b f j n q
c g k o r
d h l

如您所见,由于最后 2 个单元格为空,结构得以保留。

不是这样的:

a  e  i  m  q
b f j n r
c g k o
d h l p

在此示例中,表格类似于将其翻转到侧面。有谁知道如何正确执行此操作?

最佳答案

已编辑:这比我想象的要难,我第一次(或两次)搞砸了。它现在应该可以工作了。

假设您将表结构存储在二维数组中:

$data = array(
array('a', 'b', 'c', 'd', 'e'),
array('f', 'g', 'h', 'i', 'j'),
array('k', 'l', 'm', 'n', 'o'),
array('p', 'q', 'r')
);

由于要保持相同的“形状”,因此需要确定表格的尺寸。为此,我们可以获取第一行的 count,因为我们知道第一行必须是表格的最大宽度。高度只是数组中元素的数量。

$width = count($data[0]); // 5
$height = count($data); // 4

我们还需要元素的总数,但我们可以通过 $width * $height 来高估。

$total = $width * $height; // 20

那么计算事情的去向真的只是一点点数学。我们必须为旧索引和新索引使用单独的计数器,因为一旦我们开始有漏洞,我们将不得不以不同的方式递增它们。

$new_data = array();
$j = 0;
for($i = 0; $i < $total; $i++) {
$old_x = floor($i / $width); // integer division
$old_y = $i % $width; // modulo

do {
$new_x = $j % $height; // modulo
$new_y = floor($j / $height); // integer division
$j++;
// move on to the next position if we have reached an index that isn't available in the old data structure
} while (!isset($data[$new_x][$new_y]) && $j < $total);

if (!isset($new_data[$new_x])) {
$new_data[$new_x] = array();
}
if (isset($data[$old_x][$old_y])) {
$new_data[$new_x][$new_y] = $data[$old_x][$old_y];
}
}

关于php - 在保持表格结构的同时垂直显示表格值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17801191/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com