Answers:
您可以通过以下代码来实现,
$integerIDs = array_map('intval', explode(',', $string));
这是不是快了近3倍explode()
,array_map()
并且intval()
:
$integerIDs = json_decode('[' . $string . ']', true);
因此,我对大量整数答案中提到的某些方法的性能感到好奇。
只是创建了一个0到100之间的一百万个随机整数的数组。然后,我强加了它们以获得字符串。
$integers = array();
for ($i = 0; $i < 1000000; $i++) {
$integers[] = rand(0, 100);
}
$long_string = implode(',', $integers);
这是Mark的回答:
$integerIDs = array_map('intval', explode(',', $long_string));
这是JSON方法:
$integerIDs = json_decode('[' . $long_string . ']', true);
我想出了这个作为Mark答案的修改。这仍然在使用explode()
函数,但不是使用调用而是array_map()
使用常规foreach
循环来完成这项工作以避免产生开销array_map()
。我也在用(int)
vs进行解析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倍。事实证明,foreach
循环是我而言最快的循环。我已经使用Xdebug完成了基准测试。
编辑:距离答案最初发布已经有一段时间了。为了明确起见,基准测试是在php 5.6中完成的。
array_map(function($v){ return (int)$v; }, $strings_array);
这就是我的意思
将此代码与闭包一起使用(在中引入PHP 5.3
),它比接受的答案要快一点,对我来说,将其强制转换为整数的意图更加清楚:
// if you have your values in the format '1,2,3,4', use this before:
// $stringArray = explode(',', '1,2,3,4');
$stringArray = ['1', '2', '3', '4'];
$intArray = array_map(
function($value) { return (int)$value; },
$stringArray
);
var_dump($intArray);
输出将是:
array(4) {
[0]=>
int(1)
[1]=>
int(2)
[2]=>
int(3)
[3]=>
int(4)
}
在Mark的解决方案中,array([0]=> int 0)
如果您尝试解析诸如“ test”之类的字符串,您将返回。
$integerIDs = array_map( 'intval', array_filter( explode(',', $string), 'is_numeric' ) );
另一种较短的替代方法可能是:
$r = explode(',', $s);
foreach ($r as &$i) $i = (int) $i;
它具有与方法3相同的性能。
如果您有如下数组:
$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
因此,==可以解决您的问题,效率很高,但是如果在比较中使用===则会失败。
如果您有一个多维数组,则前面提到的解决方案都无法使用。这是我的解决方案:
public function arrayValuesToInt(&$array){
if(is_array($array)){
foreach($array as &$arrayPiece){
arrayValuesToInt($arrayPiece);
}
}else{
$array = intval($array);
}
}
然后,只需执行以下操作:
arrayValuesToInt($multiDimentionalArray);
这将使数组如下所示:
[["1","2"]["3","4"]]
看起来像这样:
[[1,2][3,4]
(这将适用于任何深度级别)
您可以转换数组中的值:
<?php
$ids = explode(',', $strings);
foreach ($ids as $index => $value) {
$ids[$index] = (int)$value;
}
您也可以将explode
函数的返回值返回$strings
并对其进行迭代,而不是使用另一个变量($ ids)。
我认为此解决方案是性能最佳的最安全方法。
输入 =>'[“ 3”,“ 6”,“ 16”,“ 120”]'
我使用的类型转换 =>(int)$ s;
function Str_Int_Arr($data){
$h=[];
$arr=substr($data,1,-1);
//$exp=str_replace( ",","", $arr);
$exp=str_replace( "\"","", $arr);
$s='';
$m=0;
foreach (str_split($exp) as $k){
if('0'<= $k && '9'>$k || $k =","){
if('0' <= $k && '9' > $k){
$s.=$k;
$h[$m]=(int)$s;
}else{
$s="";
$m+=1;
}
}
}
return $h;
}
var_dump(Str_Int_Arr('["3","6","16","120"]'));
输出:
array(4) {
[0]=>
int(3)
[1]=>
int(6)
[2]=>
int(16)
[3]=>
int(120)
}
谢谢