Search code examples
phpspl

Scan a directory of images with PHP and Increment a counter for duplicate filename matches


I have an upload folder that has images inside of it that are named in this format...

10000XXXX-COUNT-DATE-EMPLOYEE-PP-FILEEXTENSION

which looks like this...

100002246-1-2014-05-05-David.Rosales-PP.jpg

Each time a photo is uploaded using PHP I need to scan the files in this directory and find a match for the ID part which is the first 9 digits of the filename.

IF a match is found, I then need to append a number to the COUNT position which is in the number 11 character spot from the left.

The idea is an ID can have 5-6 images. If the ID has 1 image already then the next image should be named 100002246-2-2014-05-05-David.Rosales-PP.jpg and after that another image on a different upload sessions would be 100002246-3-2014-05-05-David.Rosales-PP.jpg so each new image for an ID number will increment by 1 number. You can see I have added the count number at the number 11 character spot.

I am not sure how to best achieve this right now. I cannot use a database so I have to do this during the upload process and scan the directory to find any matches for an image.

Any ideas and example of how I can best do this please?

Something like this for scanning the directory looks promising...

foreach (new DirectoryIterator('.') as $item) {
    echo $item, PHP_EOL;
}

UPDATE - My attempt at a solution so far

<?php
$orderId = $_GET['orderid'];


$dir = new DirectoryIterator('uploads');
$fileMatches = array();

foreach ($dir as $fileinfo) {

    $filenameId= substr($fileinfo->getFilename(), 0, 9);

    if($filenameId === $orderId){
        //store File ID matches in an array
        $fileMatches[] = $filenameId;
    }
    echo $fileinfo->getFilename() . "<br>";
}
$totalImages = count($fileMatches);
echo '<hr>Total Images found for this ID '.$orderId.' = '.$totalImages;
echo '<hr>New count for image would be = '. ($totalImages+1);

?>

Solution

  • You might be able to use glob() for your purposes. Supposing all pictures are in a directory named imgs:

    $user_imgs = count(glob('imgs/*'.$user_id.'*')));
    

    $user_imgs will contain the number of files in imgs that have $user_id in the file name.

    You can get more creative with the pattern, if need be. This example just finds all files that have $user_id anywhere in the file name. Up to you how specific you want to be regarding the pattern you are searching for.

    UPDATE based on your attempted solution

    You can simplify your algorithm to this:

    $orderId = $_GET['orderid'];
    
    $all_images = glob('uploads/'.$orderId.'*');
    
    foreach($all_images as $i)
        echo $i . '<br/>';
    
    $totalImages = count($all_images);
    
    echo '<hr>Total Images found for this ID '.$orderId.' = '.$totalImages;
    echo '<hr>New count for image would be = '. ($totalImages+1);
    

    UPDATE in consideration of new requirements

    $orderId = $_GET['orderid'];
    
    $all_images = glob('uploads/'.$orderId.'*');
    
    $pp = $qc = 0;
    
    foreach($all_images as $i) {
        if (strpos($i, '-PP.')!==false)
            $pp++;
        elseif (strpos($i, '-QC.')!==false)
            $qc++;
    }
    
    echo '<hr>Total Images found for this ID '.$orderId.' (PP) = '.$pp;
    echo '<hr>New count for image would be = '. ($pp+1);
    
    echo '<hr>Total Images found for this ID '.$orderId.' (QC) = '.$qc;
    echo '<hr>New count for image would be = '. ($qc+1);