匹配精确数字(_M)
我正在使用
$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
}
相关文章