以下代码:
$string = "1,2,3"
$ids = explode(',', $string);
var_dump($ids);
返回数组:
array(3) {
[0]=>
string(1) "1"
[1]=>
string(1) "2"
[2]=>
string(1) "3"
}
我需要的值是类型int而不是类型字符串。有没有更好的方法来做到这一点比循环通过数组与foreach和转换每个字符串为int?
以下代码:
$string = "1,2,3"
$ids = explode(',', $string);
var_dump($ids);
返回数组:
array(3) {
[0]=>
string(1) "1"
[1]=>
string(1) "2"
[2]=>
string(1) "3"
}
我需要的值是类型int而不是类型字符串。有没有更好的方法来做到这一点比循环通过数组与foreach和转换每个字符串为int?
当前回答
$arr = ["adfsf", "*&^%$#^", "23", "25", "29"];
function convertArrayStringToArrayInt($arr)
{
$result = [];
foreach($arr as $value) {
if ((int)$value !== 0) {
$result[] = (int)$value;
}
}
return $result;
}
$result = convertArrayStringToArrayInt($arr);
var_dump($result);
结果是这样的
array(3) {
[0]=> int(23)
[1]=> int(25)
[2]=> int(29)
}
其他回答
如果你有这样的数组:
$runners = ["1","2","3","4"];
如果你想把它们转换成整数并保持在数组中,下面应该做的工作:
$newArray = array_map( create_function('$value', 'return (int)$value;'),
$runners);
保持简单……
$intArray = array ();
$strArray = explode(',', $string);
foreach ($strArray as $value)
$intArray [] = intval ($value);
你为什么要另辟蹊径?循环毫无痛苦地完成了这项工作。如果您关心的是性能,那么可以使用json_decode()。人们已经发布了如何使用它,所以我在这里不包括它。
注意:当使用==操作符而不是===时,如果字符串值构成了一个没有引号的有效数字,则会自动转换为数字(例如整数或双精度)。例如:
$str = '1';
($str == 1) // true but
($str === 1) //false
因此,==可以解决你的问题,是有效的,但如果你在比较中使用===就会崩溃。
PHP 7.4风格:
$ids = array_map(fn(string $x): int => (int) $x, explode(',', $string));
另一种更短的方法是:
$r = explode(',', $s);
foreach ($r as &$i) $i = (int) $i;
其性能与方法3相同。
所以我很好奇答案中提到的一些方法对于大量整数的性能。
准备
只是创建一个100万个0到100之间的随机整数的数组。然后,我把它们炸了,拿到了绳子。
$integers = array();
for ($i = 0; $i < 1000000; $i++) {
$integers[] = rand(0, 100);
}
$long_string = implode(',', $integers);
方法1
这是马克回答中的一句话:
$integerIDs = array_map('intval', explode(',', $long_string));
方法2
这是JSON方法:
$integerIDs = json_decode('[' . $long_string . ']', true);
方法3
我根据马克的回答提出了这个问题。这仍然使用了explosion()函数,但是我没有调用array_map(),而是使用常规的foreach循环来完成这项工作,以避免array_map()可能带来的开销。我还使用(int)和intval()进行解析,但我都尝试了,在性能方面没有太大差异。
$result_array = array();
$strings_array = explode(',', $long_string);
foreach ($strings_array as $each_number) {
$result_array[] = (int) $each_number;
}
结果
Method 1 Method 2 Method 3
0.4804770947 0.3608930111 0.3387751579
0.4748001099 0.363986969 0.3762528896
0.4625790119 0.3645150661 0.3335959911
0.5065748692 0.3570590019 0.3365750313
0.4803431034 0.4135499001 0.3330330849
0.4510772228 0.4421861172 0.341176033
0.503674984 0.3612480164 0.3561749458
0.5598649979 0.352314949 0.3766179085
0.4573421478 0.3527538776 0.3473439217
0.4863037268 0.3742785454 0.3488383293
底线是平均值。对于100万个整数,第一种方法看起来有点慢,但我没有注意到答案中所述的方法2的性能提高了3倍。对我来说,每一个循环都是最快的。我已经用Xdebug完成了基准测试。
编辑:从最初的答案发布到现在已经有一段时间了。为了澄清,基准测试是在php 5.6.40中完成的。