1

我正在使用一种方法在表格行中列出一堆用户/信息:

"3""2""5""pg1"

假设这是我得到的数据,我该如何制作它,所以我只检索引号内的数据(作为数组)。我这样做是因为从长远来看它有助于编程。

4

4 回答 4

4

explode()如果值内不能有引号,则可以使用:

$string = '"3""2""5""pg1"';
$array = explode( '""', trim( $string, '"'));

将输出

Array
(
    [0] => 3
    [1] => 2
    [2] => 5
    [3] => pg1
)
于 2013-03-08T02:08:25.237 回答
2

您可以使用 preg_split 将其分开:

preg_split("/\"+/", STRING, -1, PREG_SPLIT_NO_EMPTY);
于 2013-03-08T02:09:35.420 回答
1

这没有完全回答,因为我还有一些探索......

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";

?>
于 2013-03-08T02:21:36.140 回答
0

可能不是最优雅的方式:

<?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
)

查看演示

于 2013-03-08T02:10:25.367 回答