ホームページ >バックエンド開発 >PHPチュートリアル >配列処理、ng数の計算
array(6) { [0]=> string(62) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020.csv" [1]=> string(64) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_1.csv" [2]=> string(64) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_2.csv" [3]=> string(64) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_3.csv" [4]=> string(64) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_4.csv" [5]=> string(65) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_NG.csv"}
この場合はどうなりますか?
foreach (glob($datapath."/NG/*.csv") as $filename) { preg_match('/.+\/(\d+)/',$filename,$match); echo $value_lotno.'=>'.$match[1].'<br />'; }
5106=>80015127=>72075127=>72075306=>70205306=>70205306=>70205306=>70205306=>70205306=>70205309=>71735309=>71735310=>71025310=>71025310=>72535310=>72535310=>74345310=>74345310=>74435310=>74435310=>75085310=>75085310=>75735310=>7573
array('5106=>8001','5127=>7207','5306=>7020','5309=>7173','5310=>7102','5310=>7253','5310=>7434','5310=>7443','5310=>7508','5310=>7573');
$arr=array( '5106=>8001', '5127=>7207', '5127=>7207', '5306=>7020', '5306=>7020', '5306=>7020', '5306=>7020', '5306=>7020', '5306=>7020', '5309=>7173', '5309=>7173', '5310=>7102', '5310=>7102', '5310=>7253', '5310=>7253', '5310=>7434', '5310=>7434', '5310=>7443', '5310=>7443', '5310=>7508', '5310=>7508', '5310=>7573', '5310=>7573',);echo "<pre class="brush:php;toolbar:false">";print_r(array_values(array_unique($arr)));echo "";/*Array( [0] => 5106=>8001 [1] => 5127=>7207 [2] => 5306=>7020 [3] => 5309=>7173 [4] => 5310=>7102 [5] => 5310=>7253 [6] => 5310=>7434 [7] => 5310=>7443 [8] => 5310=>7508 [9] => 5310=>7573)*/
$arr=array( '5106=>8001', '5127=>7207', '5127=>7207', '5306=>7020', '5306=>7020', '5306=>7020', '5306=>7020', '5306=>7020', '5306=>7020', '5309=>7173', '5309=>7173', '5310=>7102', '5310=>7102', '5310=>7253', '5310=>7253', '5310=>7434', '5310=>7434', '5310=>7443', '5310=>7443', '5310=>7508', '5310=>7508', '5310=>7573', '5310=>7573',);echo "<pre class="brush:php;toolbar:false">";print_r(array_values(array_unique($arr)));echo "";/*Array( [0] => 5106=>8001 [1] => 5127=>7207 [2] => 5306=>7020 [3] => 5309=>7173 [4] => 5310=>7102 [5] => 5310=>7253 [6] => 5310=>7434 [7] => 5310=>7443 [8] => 5310=>7508 [9] => 5310=>7573)*/
すべてループしてませんでしたか?....
echo $value_lotno.'=>'.$match[1].'df250b2156c434f3390392d09b1c9563';
以下に追加します
$arr[]=$value_lotno.'=>'.$match[1];
以上です すべてループアウトではありませんか?....
echo $value_lotno.'=>'.$match[1].'df250b2156c434f3390392d09b1c9563';
$arr[]=$value_lotno.'=>'.$match を追加します[1];
これでうまくいきます
これは私の質問であり、ループ print_r の外に配置する必要がありますが、この質問は私の当初の意図からは程遠いものです。たとえば、パス 1# の場合、パスの末尾の 7020 で始まるファイルが 1 つのファイルとして表示される場合、ng フォルダー内のファイルの数は 1 と計算されます。これをリクエストするにはどうすればよいですか?
例を見てみましょう!
次の結果を取得します。
$datapath = '../../dat/DIG/TestFunction/'.$machine.'/'.$value_type.'/'.$value_lotno;//已求得var_dump(glob($datapath.'/NG/*.*', GLOB_BRACE));取得したいこれらのパスにある、対応する NG 結果の数。 (先頭が同じ場合は1つのファイルとして扱います)
array(1) { [0]=> string(62) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5106/NG/8001.csv"}array(2) { [0]=> string(62) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5127/NG/7207.csv" [1]=> string(65) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5127/NG/7207_NG.csv"}array(0) {}array(0) {}array(6) { [0]=> string(62) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020.csv" [1]=> string(64) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_1.csv" [2]=> string(64) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_2.csv" [3]=> string(64) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_3.csv" [4]=> string(64) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_4.csv" [5]=> string(65) "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_NG.csv"}
$arr=array( "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_1.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_2.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_3.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_4.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_NG.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7021_NG.csv",//添加测试);foreach($arr as $v){ $tmp=explode('/',$v); $lastfile=array_pop($tmp); preg_match('/^(\d+)(\.|\_)/',$lastfile,$m); $arr_file[]=$m[1];}$count=count(array_unique($arr_file));echo $count;//2
7# のようなものがある場合、これは空の配列の場合は間違っており、1 になります。
$arr=array( "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_1.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_2.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_3.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_4.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_NG.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7021_NG.csv",//添加测试);foreach($arr as $v){ $tmp=explode('/',$v); $lastfile=array_pop($tmp); preg_match('/^(\d+)(\.|\_)/',$lastfile,$m); $arr_file[]=$m[1];}$count=count(array_unique($arr_file));echo $count;//2ああ、二次元かどうかで判断してください
ああ、二次元かどうかで判断してください ただ判断してください
$all=array(array( "../../dat/DIG/TestFunction/TS407/BED410-500A1/5106/NG/8001.csv"),array( "../../dat/DIG/TestFunction/TS407/BED410-500A1/5127/NG/7207.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5127/NG/7207_NG.csv",),array(),array(),array( "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_1.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_2.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_3.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_4.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_NG.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7021_NG.csv",//添加测试));foreach($all as $arr){ if(!$arr){ continue; } foreach($arr as $v){ $tmp=explode('/',$v); $lastfile=array_pop($tmp); preg_match('/^(\d+)(\.|\_)/',$lastfile,$m); $arr_file[]=$m[1]; }}$count=count(array_unique($arr_file));echo $count;//4
合計を求めているのではなく、成分の合計: 1,1, 2
どうやって見つけますか?
$all=array(array( "../../dat/DIG/TestFunction/TS407/BED410-500A1/5106/NG/8001.csv"),array( "../../dat/DIG/TestFunction/TS407/BED410-500A1/5127/NG/7207.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5127/NG/7207_NG.csv",),array(),array(),array( "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_1.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_2.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_3.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_4.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7020_NG.csv", "../../dat/DIG/TestFunction/TS407/BED410-500A1/5306/NG/7021_NG.csv",//添加测试));foreach($all as $arr){ if(!$arr){ continue; } foreach($arr as $v){ $tmp=explode('/',$v); $lastfile=array_pop($tmp); preg_match('/^(\d+)(\.|\_)/',$lastfile,$m); $arr_file[]=$m[1]; }}$count=count(array_unique($arr_file));echo $count;//4酔っているので、一度で終わらせてくれませんか、兄さん