Php 将Laravel多对多关系导出到csv
我的网站的每个成员都有能力被技能“标记”。现在,我正在尝试创建一个csv,每行填充一个成员的信息,并添加一个列,其中包含他们被标记的技能的名称 换言之:Php 将Laravel多对多关系导出到csv,php,csv,laravel-5,Php,Csv,Laravel 5,我的网站的每个成员都有能力被技能“标记”。现在,我正在尝试创建一个csv,每行填充一个成员的信息,并添加一个列,其中包含他们被标记的技能的名称 换言之: ____________________________________ |member 1 name | address | etc | skill| ____________________________________ |member 2 name | address | etc | skill| 我可以让一切都很好的工作,除了增加技
____________________________________
|member 1 name | address | etc | skill|
____________________________________
|member 2 name | address | etc | skill|
我可以让一切都很好的工作,除了增加技能的最后一行。当我尝试添加它时,会出现以下错误:
Undefined property: Illuminate\Database\Eloquent\Collection::$name
控制器
public function memberDirectoryExport()
{
$categories= $this->member->membersDirectoryExport();
//create empty array
$rows = [];
//create header row
$header = [];
//add results to header row... not important
$header[] = $this->getExportCsvTitles();
foreach ($categories as $skill) {
foreach($skill->contractors->sortBy('company_name') as $c){
$rows[]= $c->exportDirectoryCsvRow();
}
}
// merge arrays to sent to file_put_contents
$result = array_merge($header, $rows);
// Get a temp name.
list($name, $tmpFile) = self::_getCsvTmpName();
// Store the contents for Laravel to retrieve.
file_put_contents($tmpFile, implode("\n", $result));
// Force the download.
return Response::download($tmpFile, $name);
}
我正在contractor.php模型中创建我的行
public function exportDirectoryCsvRow()
{
return implode("\t", [
$this->company_name, // 1
$this->contact_firstName, // 2
$this->contact_lastName, // 3
$this->contact_email, // 4
$this->contact_address1, //5
$this->contact_address2, // 6
$this->contact_city, // 7
$this->contact_state, //8
$this->contact_postalCode, // 9
$this->contact_phoneNumber, // 10
$this->contact_fax, // 11
$this->skills->name, // This is the problem
]);
}
如果我将$this->skills->name更改为导出工作的$this->skills,以下是我的技能单元输出:
[{"id":1,"name":"Accounting","created_at":"-0001-11-30 00:00:00","updated_at":"-0001-11-30 00:00:00","deleted_at":null,"pivot":{"contractor_id":462,"skill_id":1}}]
如果知道我正在使用“where has”获取我的成员集合,可能会有所帮助
public function membersDirectoryExport()
{
$user = Sentry::getUser();
$localKey = $user->local_number;
$skills = Skill::whereHas('members', function ($query) use ($localKey) {
$query->where('local_number', '=', $localKey);
$query->where('status', '=', 'active' );
})->orderBy('name', 'asc')->get();
return $skills;
}
当我在控制器的嵌套foreach中添加($c)时,我会得到一个包含成员信息的集合。我还看到一个关系下拉列表,其中包含相关技能的信息
有人知道我是如何将技能添加到行中的吗?TIA我很确定问题在于我在我的模型上运行了exportDirectoryCsvRow()。当我将它添加到控制器并用$skill->name替换$this->skill->name时,它会工作。我很确定问题是我在我的模型上运行了exportDirectoryCsvRow()。当我将它添加到控制器并用$skill->name替换$this->skill->name时,它会工作。