匹配精确数字(_M)

2022-03-29 00:00:00 regex php preg-match

我正在使用

$regex = '/'.implode('|', 10).'/i';    
preg_match($regex, $ids)

在ID列表($ID)中查找数字10。但是,如果ID列表如下所示:

$ids = array(10, 110, 1010);

会把他们全部带回来吗?我如何才能使它找到我要查找的确切数字,而不仅仅是找到包含我要查找的数字的数字?

谢谢。

编辑:

我在上面犯了一个错误。ID列表实际上是逗号分隔值的字符串。例如:

$ids = "10,1010,101";

很难解释这背后的整个想法过程,但这是我的完整代码:

<?php
$file  = fopen('allprods.csv', 'r');


$id = array($_GET['id']);    
$id = array_map('preg_quote', $id);
$regex = '/'.implode('|', $id).'/i';

$skus = array();
while (($line = fgetcsv($file)) !== FALSE) {  
    list($ids, $sku) = $line;

    if(preg_match($regex, $ids)) {
    $skus[] = $sku;
    }
}

$count = count($skus);
$i = 1;

echo $category_id;
foreach ($skus as $sku){
        echo $sku;
        if($i != $count) { echo "`"; }
        $i++;
}

我实际上是在遍历一个CSV,它有一个ID列(有些行在该列中有多个ID,以逗号开头)和一个sku列。更多信息here

因此,我需要代码来检查特定ID的ID字符串,例如10,然后将适当的SKU添加到sku数组中。

我敢肯定这段代码是一团糟,所以请原谅我,让我把PHP分解成碎片!

编辑:现在问题已解决!正如答案中所提到的,我使用的是inarray值。首先,我分解了逗号分隔的字符串。代码如下:

$skus = array();
while (($line = fgetcsv($file)) !== FALSE) {  
    list($ids, $sku) = $line;

    $cats = explode(',',$ids);

    if (in_array($_GET['id'], $cats)) {
        $skus[] = $sku;
    }
}

感谢大家的帮助。


解决方案

不要为此使用正则表达式。使用in_array()

if( in_array(10, $ids) ) {
     // do something
}
else {
     // not found
}

相关文章