다중 값 특성 관련 작업
다중 값 필드로 작업하는 경우가 있습니다. 다음 예를 생각해 보십시오.
- 사용자에게 영화를 제공하고 있습니다. 해당 영화에는 여러 명의 배우들이 출연합니다.
- 콘서트 티켓을 판매합니다. 해당 사용자에는 여러 좋아하는 밴드가 출연합니다.
- 의류를 판매합니다. 셔츠는 여러 가지 크기로 구입할 수 있습니다.
이러한 시나리오에서 권장 사항을 처리하기 위해 다중 값 데이터를 Target Recommendations에 전달하고 특수 다중 값 연산자를 사용할 수 있습니다.
Recommendations이(가) 다중 값 데이터를 식별하도록 하려면 아래 코드 샘플에서와 같이 JSON 배열로 전송해야 합니다.
JavaScript에서 다중 값 매개 변수 전달
function targetPageParams() {
return {
'entity.id': '123',
'entity.categoryId': '["A", "A:B", "A:B:C", "A:B:C:D"]',
'entity.MultiValueAttribute': '["X", "Y", "Z"]',
'entity.event.detailsOnly': 'true',
'excludedIds": '[123, 3232, 2323, 4344]',
'orderId": '123456',
'orderTotal": '195.32',
'productPurchaseId": '[001,002,003]'
};
}
자세한 내용은 사용자 지정 엔터티 특성 에서 다중 값 특성 구현을 참조하십시오.
CSV 파일에 다중 값 엔티티 속성 전달
## RECSRecommendations Upload File,,,,,,,,,,,,,,,,,,,
## RECS''## RECS'' indicates a Recommendations pre-process header. Please do not remove these lines.,,,,,,,,,,,,,,,,,,,
## RECS,,,,,,,,,,,,,,,,,,,
## RECSUse this file to upload product display information to Recommendations. Each product has its own row. Each line must contain 19 values and if not all are filled a space should be left.,,,,,,,,,,,,,,,,,,,
## RECSThe last 100 columns (entity.custom1 - entity.custom100) are custom. The name 'customN' can be replaced with a custom name such as 'onSale' or 'brand'.,,,,,,,,,,,,,,,,,,,
## RECSIf the products already exist in Recommendations then changes uploaded here will override the data in Recommendations. Any new attributes entered here will be added to the product''s entry in Recommendations.,,,,,,,,,,,,,,,,,,,
## RECSentity.id ,entity.name,entity. categoryId ,entity. message ,entity.thumbnailUrl ,entity.value ,entity.pageUrl ,entity.inventory ,entity.margin ,entity.custom1 ,entity.custom2 ,entity.custom3 ,entity.custom4,entity.custom5,entity.custom6,entity.custom7,entity.custom8,entity.custom9,entity.custom10,
1,Sample Product 1,category1,Save 10%,http://sample.store/products/images/product1_th.jpg,325,http://sample.store/products/product_detail.jsp?productId=1,1000,48,a,"[ ""v1"", ""v2"" ]",, , , , , , , ,
2,Sample Product 2,category1,Save 10%,http://sample.store/products/images/product2_th.jpg,369,http://sample.store/products/product_detail.jsp?productId=2,1000,52,a,"[ ""v1"", ""v2"" ]",, , , , , , , ,
3,Sample Product 3,category1,Save 10%,http://sample.store/products/images/product3_th.jpg,479,http://sample.store/products/product_detail.jsp?productId=3,1000,78,a,"[ ""v1"", ""v2"" ]",,,,,,,,,
4,Sample Product 4,category1,Save 10%,http://sample.store/products/images/product4_th.jpg,409,http://sample.store/products/product_detail.jsp?productId=4,1000,66,a,"[ ""v1"", ""v2"" ]",,,,,,,,,
5,Sample Product 5,category1,Save 10%,http://sample.store/products/images/product5_th.jpg,325,http://sample.store/products/product_detail.jsp?productId=5,1000,45,a,"[ ""v1"", ""v2"" ]",,,,,,,,,
엔터티 특성, 프로필 특성 또는 mbox 매개 변수가 위의 형식에 따라 다중 값으로 제공되면 Recommendations은(는) 필드가 다중 값임을 자동으로 유추합니다.
다음 연산자는 다중 값 엔티티, 프로필 및 mbox 속성과 함께 사용할 수 있습니다.
- is contained in list
- is not contained in list
포함 규칙에서 다중 값 속성 작업
예: 최근에 시청한 항목 제외
사용자의 마지막 10개 시청 동영상에 포함된 영화가 추천되지 않도록 하려는 경우 먼저 user.lastWatchedMovies
(이)라는 프로필 스크립트를 작성하여 마지막으로 본 10개의 동영상을 JSON 배열로 추적합니다. 그런 다음 다음 다음 포함 규칙을 사용하여 항목을 제외할 수 있습니다.
`Profile Attribute Matching`
`id - is not contained in list - user.lastWatchedMovies`
포함 규칙의 JSON API 표시:
{
"attribute": "id",
"operation": "isNotContainedInList",
"source": {
"name": "user.lastWatchedMovies",
"type": "PROFILE"
}
}
예: 사용자의 즐겨찾기에서 항목 추천
연주하는 밴드가 사용자가 좋아하는 밴드 중 하나인 경우 콘서트에만 티켓을 추천하고 싶다고 가정해 보자. 먼저 profile.favoriteBands
(이)라는 프로필 변수에 사용자가 좋아하는 밴드가 포함되어 있는지 확인하십시오. 그런 다음 카탈로그에 콘서트에서 공연하는 아티스트가 포함된 특성 entity.artistPerforming
이(가) 포함되어 있는지 확인하십시오. 그런 다음 다음 다음 포함 규칙을 사용할 수 있습니다.
`Profile Attribute Matching`
`artistPerforming - is contained in list - profile.favoriteBands`
포함 규칙의 JSON API 표시:
{
"attribute": "artistPerforming",
"operation": "isContainedInList",
"source": {
"name": "profile.favoriteBands",
"type": "PROFILE"
}
}
예: 사용자의 즐겨찾기에서 항목을 추천하는 기준의 API 생성
모든 기준과 마찬가지로 다중 값 필터링 규칙을 사용하는 기준은 Adobe I/O API를 통해 만들 수 있습니다. 엔터티 특성 id
이(가) mbox 매개 변수 목록 favorites
에 포함된 기준을 만드는 예제 API 호출이 여기에 제공됩니다.
curl -X POST \
https://<serverhost>/api/recs/<client>/criteria/item \
-H 'Accept: application/vnd.adobe.target.v1+json' \
-H 'Accept-Encoding: gzip, deflate' \
-H 'Cache-Control: no-cache' \
-H 'Connection: keep-alive' \
-H 'Content-Type: application/json' \
-H 'User-Agent: <from API client>' \
-H 'X-Target-user-email: <email address>' \
-H 'cache-control: no-cache' \
-d '{
"name": "viewed criteria",
"criteriaTitle": "test title",
"type": "VIEWED_CF",
"key": "CURRENT",
"daysCount": "TWO_WEEKS",
"aggregation": "NONE",
"backupDisabled": false,
"partialDesignAllowed": true,
"configuration": {
"inclusionRules": [
{
"attribute": "id",
"operation": "isContainedInList",
"source": {
"name": "mbox.favorites",
"type": "MBOX"
}
}
]
}
}'
이 플러그인은 페이지의 JavaScript과 쌍을 이루어 즐겨찾기 컨텐츠를 전달합니다.
<!-- pass in the value of mbox parameter “favorites” as JSON array -->
<script type="text/javascript">
mboxCreate('myMbox','entity.id=<key>','favorites=["a","b","c"]');
</script>