Php Laravel Excel是否将设置值导出到单元格?

Php Laravel Excel是否将设置值导出到单元格?,php,excel,laravel-5,laravel-excel,Php,Excel,Laravel 5,Laravel Excel,我使用maatwebsite excel库导入和导出数据。 我想将单元格数据设置为 A B C D E F 1 heading1 heading2 heading3 heading4 heading5 heading6 2 data1 data2 data3 data4 data5 data6 3 data12 da

我使用maatwebsite excel库导入和导出数据。 我想将单元格数据设置为

    A          B         C          D          E          F
1   heading1   heading2  heading3   heading4   heading5   heading6
2   data1      data2     data3      data4      data5      data6
3   data12     data22    data32     data42     data52     data62
4              data23    data33     data43     data53     
5                        data34     data44     data54
6                        data35     data45     data54
7                                   data46     data56
8                                   data47     data57
9                                   data48
10                                  data49
11                                  data50
12                                  data51
我想导出这样的数据,我尝试了很多,但没有成功

下面是我的代码

$sheet->fromArray($dataHeading);
我使用此函数为excel文件添加值。但问题是这个函数在原始状态下增加值,我想在单元格状态下增加值

首先,我向
A
添加值,然后向
B
等添加值

我找不到任何函数允许我在单元格方面增加值

请帮助我如何处理这个问题。我有像php数组一样的数据

array(
   'heading1' => array(
       'data1','data12'
    ),
    'heading2' => array(
        'data2','data22','data23'
    ),
    'heading3' => array(
        'data3','data32','data33','data34','data35'
    ),
    'heading4' => array(
        'data4','data42','data43','data44','data45','data46','data47','data47','data49','data50','data51'
    ),
    'heading5' => array(
         'data5','data52','data53','data54','data56','data57'
    ),
    'heading6' => array(
         'data6','data62'
    )
)
如何将此数组输入excel文件。如果我需要更改阵列,请建议我。我可以更改我的数组


感谢您使用此功能并在最后更改文件扩展名(xls、csv等),您将获得所需的文件和正确的数据

public function exportCSV(Request $request){
    $data = array();
    $messageemail           =   '';
    $data['usertotal']      =   User::select('name','email','mobile')->orderBy('name','ASC')->get();
    $data['total-user']     =   array();
    $percounting            =   0;
        foreach($data['usertotal'] as $datanew){
            $data['total-user'][$percounting]['email']                  = $datanew->email;
            $data['total-user'][$percounting]['mobile']                 = $datanew->mobile;
            $data['total-user'][$percounting]['name']                   = $datanew->name;
            $percounting++;
        }
        /* Start Exporting Data */
        Excel::create(time(), function($excel) use($data) {
             $excel->sheet('Sheetname', function($sheet) use($data) {
             $datasheet = array();
             $datasheet[0]  =   array('email','mobile','fullname');
             $i=1;
             foreach($data['total-user'] as $datanew){
                        $datasheet[$i] = array( @$datanew['email'],
                        $datanew['mobile'],  
                        $datanew['name'],
                    );
                $i++;
             }
            $sheet->fromArray($datasheet);
            });

        })->export('xls');

    return Redirect::back();


}

注:此功能是maatwebsite软件包所必需的。如果您不想使用这个包,那么也可以通过核心php库来实现

不确定它是否解决了您的问题,但看到的标题是:有些人试图只设置单个单元格的值,结果可能会出现在这里:)

虽然没有文档记录,但通过查看源代码,我发现这是可能的:

$sheet->setCellValue('A1', 'some value');


有点离题,但我希望它能帮助一些人。

很抱歉,此代码不适用于我,谢谢。假设我现在有10个手机号码、5个电子邮件地址和3个姓名,你的功能运行正常,没有出现任何错误?当然,这个功能运行良好,因为我在2年前创建了这个功能,并一直使用到现在。如果此函数不适用于您,则必须检查代码。如果您无法执行此操作,请将代码和数据库发送到我的电子邮件地址。请将我的数组存储到
$data['usertotal']
,然后检查我得到的错误。
$sheet->cell('A1', function($cell) {
    $cell->setValue('some value');
});