当我将Feed导入实体引用字段时,它会创建类似于下面代码的重复值(使用devel模块)
$field_tags_people['und'][0]['target_id'] = 578
$field_tags_people['und'][1]['target_id'] = 578
$field_tags_people['und'][2]['target_id'] = 594
每个target_id应该有不同的值,但结果有些是重复的。我试过这段代码
$field_tags_people['und'] = array_unique($field_tags_people['und'])
但它删除了除第一个之外的所有术语。由于target_id键,这看起来很奇怪。我怎样才能做到这一点?
答案 0 :(得分:0)
可能有更好的方法来实现这一目标,但这是一个解决方案。
$unique = [];
$field_tags_people['und'] = array_filter($field_tags_people['und'],
function ($val) use (&$unique) {
if (!in_array($val['target_id'],$unique)) {
$unique[] = $val['target_id'];
return true;
}
return false;
}
);
unset($unique);
这将为你重复修复。但请注意,密钥结构不会被重置,因此您可以按顺序输入密钥,如0,1,6,7,10
干杯
编辑:在线示例:http://sandbox.onlinephpfunctions.com/code/9b4323a0b07ab8cd46b34a3715ea030f83e0b100
答案 1 :(得分:0)
我通过在自定义模块中实现hook_feeds_presave
解决了这一问题。
以下内容通过键field_my_field_name
在value
中检查数组中的重复项,并在导入/保存节点之前将其删除。
<?php
function my_module_feeds_presave(FeedsSource $source, $entity, $item) {
$items_array = $entity->field_my_field_name[LANGUAGE_NONE];
$entity->field_my_field_name[LANGUAGE_NONE] = unique_multidim_array($items_array,'value');
}
function unique_multidim_array($array, $key) {
$temp_array = array();
$i = 0;
$key_array = array();
foreach($array as $val) {
if (!in_array($val[$key], $key_array)) {
$key_array[$i] = $val[$key];
$temp_array[$i] = $val;
}
$i++;
}
return $temp_array;
}
?>
答案 2 :(得分:0)
/**
* Delete duplicate values.
*
* @param \Drupal\Core\Entity\ContentEntityInterface $entity
* Entity.
* @param string $field_name
* Field name.
* @param bool $need_save
* Save entity or not.
*
* @throws \Drupal\Core\Entity\EntityStorageException
*/
public static function deleteDuplicateValues(ContentEntityInterface $entity, string $field_name, $need_save = FALSE) {
$result = [];
/** @var \Drupal\Core\Field\EntityReferenceFieldItemListInterface $reference_field */
$reference_field = $entity->get($field_name);
$referenced_entities = $reference_field->referencedEntities();
/** @var \Drupal\Core\Entity\ContentEntityInterface $item */
foreach ($referenced_entities as $item) {
$result[$item->id()] = $item;
}
$entity->set($field_name, $result);
if ($need_save) {
$entity->save();
}
}
并像这样使用它:
CLASS_NAME::deleteDuplicateValues($entity, 'tags_people');