我正在使用一种方法在表格行中列出一堆用户/信息:
"3""2""5""pg1"
假设这是我得到的数据,我该如何制作它,所以我只检索引号内的数据(作为数组)。我这样做是因为从长远来看它有助于编程。
您可以使用 preg_split 将其分开:
preg_split("/\"+/", STRING, -1, PREG_SPLIT_NO_EMPTY);
这没有完全回答,因为我还有一些探索......
TRIM 不比 ltrim 和 rtrim 快吗?看例子...
<?php
// FASTEST: 0.13544297218323 ms
$a1 = microtime(true);
for ($i=0; $i<=100000; $i++) {
$string = '"3""2""5""pg1"';
$array = explode( '""', trim( $string, '"'));
}
$a1e = microtime(true);
$a1r = $a1e-$a1;
// MIDDLE FAST: 0.2419900894165 ms
$a2 = microtime(true);
for ($i=0; $i<=100000; $i++) {
$string = '"3""2""5""pg1"';
$string = rtrim(ltrim(str_replace('""', ',', $string), '"'), '"');
$pieces = explode(',', $string);
}
$a2e = microtime(true);
$a2r = $a2e-$a2;
// MIDDLE 0.20940399169922 ms!
$a3 = microtime(true);
for ($i=0; $i<=100000; $i++) {
$re = preg_split("/\"+/", $string, -1, PREG_SPLIT_NO_EMPTY);
$pieces = explode(',', $re[0]);
}
$a3e = microtime(true);
$a3r = $a3e-$a3;
echo $a1r."\r\n";
echo $a2r."\r\n";
echo $a3r."\r\n";
?>
可能不是最优雅的方式:
<?php
$string = '"3""2""5""pg1"';
$string = rtrim(ltrim(str_replace('""', ',', $string), '"'), '"');
$pieces = explode(',', $string);
print_r($pieces);
结果
大批 ( [0] => 3 [1] => 2 [2] => 5 [3] => pg1 )