我有值:1,5,7,2,25,2,6
,我想为所有值指定一个与颜色有关的特定百分比。
因此,最高值为25
-100%。
最低值为1
-10%。
具有这些数字后,我想检查其他数字%,但是我想对其他10种颜色做同样的事情:
.100 {
color: rgb(30, 144, 255);
}
.90 {
color: rgba(30, 144, 255, 0.9);
}
.80 {
color: rgba(30, 144, 255, 0.8);
}
.70 {
color: rgba(30, 144, 255, 0.7);
}
.60 {
color: rgba(30, 144, 255, 0.6);
}
.50 {
color: rgba(30, 144, 255, 0.5);
}
.40 {
color: rgba(30, 144, 255, 0.4);
}
.30 {
color: rgba(30, 144, 255, 0.3);
}
.20 {
color: rgba(30, 144, 255, 0.2);
}
.10 {
color: rgba(30, 144, 255, 0.1);
}
我到目前为止尝试过:
$a_c_a = '1,5,7,2,25,2,6';
$a_c_a_min = min(array_filter($a_c_s));
$a_c_a_max = max(array_filter($a_c_s));
$a_c_a_min_10 = $a_c_a_min;
$a_c_a_max_100 = $a_c_a_max;
if (1 == $a_c_a_max) {
$class_2 = '.100';
} elseif (1 == $a_c_a_min) {
$class_2 = '.10';
}
if (5 == $a_c_a_max) {
$class_3 = '.100';
} elseif (5 == $a_c_a_min) {
$class_3 = '.10';
}
if (7 == $a_c_a_max) {
$class_4 = '.100';
} elseif (7 == $a_c_a_min) {
$class_4 = '.10';
}
[...] up to number 6
输出应为:
$class_1 = '.50'; (1)
$class_2 = '.70'; (5)
$class_3 = '.90'; (7)
$class_4 = '.60'; (2)
$class_5 = '.100'; (25)
$class_6 = '.60'; (2)
$class_7 = '.80'; (6)
注意:同样,如果值将为1,2,1,1,3
,那么我想使用.100
和.90
和.80
-从最高开始。
答案 0 :(得分:1)
首先使用array_unique()
获取数组的所有不同值,然后使用sort()
对其进行排序。然后,您可以创建一个关联数组,将这些排序后的值映射到相应的百分比。
$percentages = array(100, 90, 80, 70, 60, 50, 40, 30, 20, 10);
$unique_values = array_map('intval', array_unique($a_c_s));
rsort($unique_values);
$percent_map = array_combine($unique_values, array_slice($percentages, 0, count($unique_values)));
foreach ($a_c_a as $val) {
echo $val . " - " . $percent_map[$val] . "%<br>";
}