laravel 导入导出功能根据title匹配数据公共方法

1、获取excel数据,根据title跟数据可字段匹配

if (!function_exists('getExcelDataByTitle')) {
    function getExcelDataByTitle($title, $fileData)
    {
        $oneLine = array_shift($fileData);
        $titleFlip = array_flip($title);
        foreach ($oneLine as $key => $label) {
            if (isset($titleFlip[$label])) {
                $col = $titleFlip[$label];
                $current_title[] = $col;
            } else {
                $current_title[] = 'empty';
            }
        }

        $result = [];
        foreach ($fileData as $key => $row) {
            $isValid = false;
            foreach ($row as $k => $v) {
                $col = $current_title[$k];
                $result[$key][$col] = null;
    
                if (!is_null($v)) $isValid = true;
                if ($col != 'empty' && isset($v)) $result[$key][$col] = trim($v);
            }
            if ($isValid === false) unset($result[$key]);
        }
        return $result;

    }
}

2、获取导出数据,根据title跟数据可字段匹配

if (!function_exists('getExportDataByTitle')) {
    function getExportDataByTitle($title, $fileData)
    {
        $titleFlip = array_flip(array_values(array_flip($title)));
        $result = [];
        $index = 1;
        foreach ($fileData as $key => $row) {
            foreach ($titleFlip as $col => $i) {
                if (stripos($col, '.')) {
                    $allKey = explode('.', $col);
                    $res = $row;
                    foreach ($allKey as $k) {
                        $res = $res[$k] ?? null;
                    }
                    $result[$key][$i] = $res;
                } else {
                    if (isset($row[$col])) {
                        $value = $row[$col];
                        /*if (is_array($value)) {
                            $value = $value['label'] ?? $value['name'] ?? (string)$value;
                        }*/
                        $result[$key][$i] = $value;
                    } else {
                        $result[$key][$i] = '';
                    }
                    if ($col == 'index') $result[$key][$i] = (string)$index;
                }
            }
            $index++;
        }
        array_unshift($result, array_values($title));
        return $result;
    }

}

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值