Magento2根据图片文件包导入产品图片

图片包给的图片文件是子产品的图片,如下图:A104255是主产品的sku

php 复制代码
<?php

/**
 * 根据图片包导入产品图片,包含子产品和主产品
 * 子产品是作为主图,主产品是作为附加图片
 */

use Magento\Framework\App\Bootstrap;

include('../app/bootstrap.php');
$bootstrap = Bootstrap::create(BP, $_SERVER);

$objectManager = \Magento\Framework\App\ObjectManager::getInstance();
/** @var \Magento\Framework\App\ResourceConnection $resource */
$resource = $objectManager->get('\Magento\Framework\App\ResourceConnection');
$connection = $resource->getConnection(\Magento\Framework\App\ResourceConnection::DEFAULT_CONNECTION);

$directory = $objectManager->get('\Magento\Framework\Filesystem\DirectoryList');

$obj = $bootstrap->getObjectManager();

$state = $obj->get('Magento\Framework\App\State');
$state->setAreaCode('adminhtml');

/** @var  \Magento\Catalog\Model\ProductFactory $productFactory */
$productFactory = $objectManager->create('\Magento\Catalog\Model\ProductFactory');

/** @var  \Magento\Catalog\Model\ResourceModel\MediaImageDeleteProcessor $mediaImageDeleteProcessor */
$mediaImageDeleteProcessor = $objectManager->create('\Magento\Catalog\Model\ResourceModel\MediaImageDeleteProcessor');

$imageFolder = $directory->getRoot().'/pub/media/images_import';
$delUrl = $directory->getRoot().'/pub/media/catalog/product';

$existsSku = [];

try {
    // 指定搜索的文件夹和文件名进行搜索
    $folder = $imageFolder;
    //$fileName = $sku;
    $fileName = '*.jpg';

    // 执行搜索并获取结果数组
    $imgfiles = searchImagesInFolder($folder, $fileName);
    //print_r($imgfiles);die;

    if ($imgfiles) {
        foreach ($imgfiles as $imgfile) {
            try {
                $mainImagePath = $imgfile;
                if(is_file($mainImagePath)){
                    $pathArr = explode('/', $mainImagePath);
                    $imgName = end($pathArr);

                    $sku = explode('.', $imgName)[0];
                    if (in_array($sku, $existsSku)) continue;
                    //if ($sku != 'B302170-5g') continue;

                    //var_dump($sku);die;

                    $sql = $connection->select()->from('catalog_product_entity')
                        ->where('sku = ?', $sku);
                    $row = $connection->fetchRow($sql);
                    if (!$row) {
                        echo $sku,' 不存在',PHP_EOL;
                        continue;
                    }

                    $product = $productFactory->create()->loadByAttribute('sku',$sku);
                    $rowId = $product->getRowId();

                    if (strstr($sku, '-')){ #主图
                        #删除原有的图片
                        /*$del = $connection->fetchAll("SELECT * from catalog_product_entity_media_gallery where value_id in( select value_id from catalog_product_entity_media_gallery_value_to_entity where row_id='{$rowId}')");
                        foreach ($del as $key=>$value){
                            if (file_exists($delUrl.'/'.$value['value'])) {
                                unlink($delUrl . '/' . $value['value']);
                            }
                        }

                        # 删除产品和图片的关联关系
                        $connection->query("delete from catalog_product_entity_media_gallery where value_id in( select value_id from catalog_product_entity_media_gallery_value_to_entity where row_id='{$rowId}')");
                        $connection->query("delete from catalog_product_entity_media_gallery_value_to_entity where row_id='{$rowId}'");
                        $connection->query("delete from catalog_product_entity_varchar where row_id='{$rowId}' and attribute_id in(87,88,89)");*/

                        echo $sku,' 主图',PHP_EOL;
                        $product->setStoreId(0)->addImageToMediaGallery($mainImagePath, array('image', 'small_image', 'thumbnail'), false, false);
                    }

                    $product->save();

                    #作为主产品的附加图
                    $sku_master = explode('-', $sku)[0] ?? '';
//                    var_dump($sku_master);die;

                    if (!$sku_master) continue;
                    if (in_array($sku_master, $existsSku)) continue;

                    $sql = $connection->select()->from('catalog_product_entity')
                        ->where('sku = ?', $sku_master);
                    $row = $connection->fetchRow($sql);
                    if (!$row) {
                        echo $sku_master,' 不存在',PHP_EOL;
                        continue;
                    }

                    $product_master = $productFactory->create()->loadByAttribute('sku',$sku_master);
                    $rowId = $product_master->getRowId();

                    #主产品导完删除图片
                    $product_master->setStoreId(0)->addImageToMediaGallery($mainImagePath, [], true, false);
                    $product_master->save();
                    echo $sku_master,' 子图',PHP_EOL;
                }else{
                    echo $sku." skip\n";
                }
            } catch (\Exception $e){
                throw new Exception($e->getMessage());
            }
        }
    } else {
        echo "没有找到匹配的文件。",PHP_EOL;
    }

} catch (\Exception $e){
    echo $e->getMessage(),PHP_EOL;
}
//    }
//}

function searchImagesInFolder($folder, $fileName)
{
    // 检查文件夹是否存在
    if (!is_dir($folder)) {
        return [];
    }

    // 初始化结果数组
    $result = [];

    // 打开文件夹
    $handle = opendir($folder);

    // 遍历文件夹中的文件和子文件夹
    while (($file = readdir($handle)) !== false) {
        if ($file != '.' && $file != '..') {
            $path = $folder . DIRECTORY_SEPARATOR . $file;

            // 如果是文件夹,则递归调用自身进行进一步搜索
            if (is_dir($path)) {
                $result = array_merge($result, searchImagesInFolder($path, $fileName));
            } else {
                // 如果是图片文件并且文件名与模糊匹配成功,则将文件路径添加到结果数组中
                if (isImageFile($file) && fnmatch("*{$fileName}*", $file)) {
                    $result[] = $path;
                }
            }
        }
    }

    // 关闭文件夹
    closedir($handle);

    return $result;
}

// 检查文件是否为图片文件
function isImageFile($file)
{
    $imageExtensions = ["jpg", "jpeg", "png", "gif"];
    $fileExtension = pathinfo($file, PATHINFO_EXTENSION);
    return in_array($fileExtension, $imageExtensions);
}
相关推荐
zimoyin3 小时前
webman 使用 PHPUnit
php
万世浮华戏骨3 小时前
PHP 与数据库交互 与 SQL注⼊漏洞
数据库·sql·php
Johnstons4 小时前
网络可观测性落地指南:从“出了问题才排查“到“实时感知全网状态“
开发语言·网络·php
heRs BART4 小时前
Ubuntu 20.04配置网络
网络·ubuntu·php
2501_948114246 小时前
大模型API调用成本优化的工程路径:星链4SAPI聚合网关的技术实践
大数据·开发语言·人工智能·架构·php
宋拾壹6 小时前
php网站小程序接入抖音团购核销
android·小程序·php
niucloud-admin7 小时前
PHP SAAS 框架常见问题——安装应用时提示 “未找到 admin 源码所在目录”
php
藤原千花的败北7 小时前
PHP对象注入(PHP反序列化漏洞)
网络安全·php
秋风&萧瑟7 小时前
【Linux系统编程】进程间的通信-管道
linux·服务器·php
淘矿人8 小时前
2026大模型API中转平台深度评测:weelinking领衔五大服务商横向实测与选型指南
开发语言·人工智能·python·oracle·数据挖掘·php·pygame