mirror of
https://github.com/trustgraph-ai/trustgraph.git
synced 2026-04-25 08:26:21 +02:00
568 lines
18 KiB
Markdown
568 lines
18 KiB
Markdown
|
|
---
|
|||
|
|
layout: default
|
|||
|
|
title: "Спецификация дескриптора структурированных данных"
|
|||
|
|
parent: "Russian (Beta)"
|
|||
|
|
---
|
|||
|
|
|
|||
|
|
# Спецификация дескриптора структурированных данных
|
|||
|
|
|
|||
|
|
> **Beta Translation:** This document was translated via Machine Learning and as such may not be 100% accurate. All non-English languages are currently classified as Beta.
|
|||
|
|
|
|||
|
|
## Обзор
|
|||
|
|
|
|||
|
|
Дескриптор структурированных данных - это язык конфигурации на основе JSON, который описывает, как анализировать, преобразовывать и импортировать структурированные данные в TrustGraph. Он предоставляет декларативный подход к импорту данных, поддерживающий различные форматы входных данных и сложные конвейеры преобразований без необходимости написания пользовательского кода.
|
|||
|
|
|
|||
|
|
## Основные понятия
|
|||
|
|
|
|||
|
|
### 1. Определение формата
|
|||
|
|
Описывает тип входного файла и параметры анализа. Определяет, какой анализатор использовать и как интерпретировать исходные данные.
|
|||
|
|
|
|||
|
|
### 2. Отображения полей
|
|||
|
|
Отображает пути источника на целевые поля с преобразованиями. Определяет, как данные передаются из исходных источников в поля выходной схемы.
|
|||
|
|
|
|||
|
|
### 3. Конвейер преобразований
|
|||
|
|
Цепочка преобразований данных, которые могут быть применены к значениям полей, включая:
|
|||
|
|
Очистка данных (удаление лишних пробелов, нормализация)
|
|||
|
|
Преобразование формата (разбор дат, приведение типов)
|
|||
|
|
Вычисления (арифметические операции, манипуляции со строками)
|
|||
|
|
Поиск (таблицы ссылок, замены)
|
|||
|
|
|
|||
|
|
### 4. Правила проверки
|
|||
|
|
Проверки качества данных, применяемые для обеспечения целостности данных:
|
|||
|
|
Проверка типов
|
|||
|
|
Проверки диапазонов
|
|||
|
|
Сопоставление с образцом (регулярные выражения)
|
|||
|
|
Проверка обязательных полей
|
|||
|
|
Пользовательская логика проверки
|
|||
|
|
|
|||
|
|
### 5. Глобальные настройки
|
|||
|
|
Конфигурация, применяемая ко всему процессу импорта:
|
|||
|
|
Таблицы поиска для обогащения данных
|
|||
|
|
Глобальные переменные и константы
|
|||
|
|
Спецификации формата вывода
|
|||
|
|
Политики обработки ошибок
|
|||
|
|
|
|||
|
|
## Стратегия реализации
|
|||
|
|
|
|||
|
|
Реализация импортера следует следующей схеме:
|
|||
|
|
|
|||
|
|
1. **Анализ конфигурации** - Загрузка и проверка JSON-дескриптора
|
|||
|
|
2. **Инициализация анализатора** - Загрузка соответствующего анализатора (CSV, XML, JSON и т.д.) на основе `format.type`
|
|||
|
|
3. **Применение предварительной обработки** - Выполнение глобальных фильтров и преобразований
|
|||
|
|
4. **Обработка записей** - Для каждой входной записи:
|
|||
|
|
Извлечение данных с использованием путей источника (JSONPath, XPath, имена столбцов)
|
|||
|
|
Применение преобразований на уровне поля в последовательности
|
|||
|
|
Проверка результатов на соответствие определенным правилам
|
|||
|
|
Применение значений по умолчанию для отсутствующих данных
|
|||
|
|
5. **Применение постобработки** - Выполнение дедупликации, агрегации и т.д.
|
|||
|
|
6. **Генерация вывода** - Создание данных в указанном целевом формате
|
|||
|
|
|
|||
|
|
## Поддержка выражений путей
|
|||
|
|
|
|||
|
|
Различные форматы входных данных используют соответствующие языки выражений путей:
|
|||
|
|
|
|||
|
|
**CSV**: Имена столбцов или индексы (`"column_name"` или `"[2]"`)
|
|||
|
|
**JSON**: Синтаксис JSONPath (`"$.user.profile.email"`)
|
|||
|
|
**XML**: Выражения XPath (`"//product[@id='123']/price"`)
|
|||
|
|
**Fixed-width**: Имена полей из определений полей
|
|||
|
|
|
|||
|
|
## Преимущества
|
|||
|
|
|
|||
|
|
**Единая кодовая база** - Один импортер обрабатывает несколько форматов входных данных
|
|||
|
|
**Удобство использования** - Пользователи, не являющиеся специалистами, могут создавать конфигурации
|
|||
|
|
**Повторное использование** - Конфигурации можно обмениваться и версионировать
|
|||
|
|
**Гибкость** - Сложные преобразования без пользовательского кода
|
|||
|
|
**Надежность** - Встроенная проверка и комплексная обработка ошибок
|
|||
|
|
**Поддерживаемость** - Декларативный подход снижает сложность реализации
|
|||
|
|
|
|||
|
|
## Спецификация языка
|
|||
|
|
|
|||
|
|
Дескриптор структурированных данных использует формат конфигурации JSON со следующей структурой верхнего уровня:
|
|||
|
|
|
|||
|
|
```json
|
|||
|
|
{
|
|||
|
|
"version": "1.0",
|
|||
|
|
"metadata": {
|
|||
|
|
"name": "Configuration Name",
|
|||
|
|
"description": "Description of what this config does",
|
|||
|
|
"author": "Author Name",
|
|||
|
|
"created": "2024-01-01T00:00:00Z"
|
|||
|
|
},
|
|||
|
|
"format": { ... },
|
|||
|
|
"globals": { ... },
|
|||
|
|
"preprocessing": [ ... ],
|
|||
|
|
"mappings": [ ... ],
|
|||
|
|
"postprocessing": [ ... ],
|
|||
|
|
"output": { ... }
|
|||
|
|
}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### Определение формата
|
|||
|
|
|
|||
|
|
Описывает формат входных данных и параметры разбора:
|
|||
|
|
|
|||
|
|
```json
|
|||
|
|
{
|
|||
|
|
"format": {
|
|||
|
|
"type": "csv|json|xml|fixed-width|excel|parquet",
|
|||
|
|
"encoding": "utf-8",
|
|||
|
|
"options": {
|
|||
|
|
// Format-specific options
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
#### Варианты формата CSV
|
|||
|
|
```json
|
|||
|
|
{
|
|||
|
|
"format": {
|
|||
|
|
"type": "csv",
|
|||
|
|
"options": {
|
|||
|
|
"delimiter": ",",
|
|||
|
|
"quote_char": "\"",
|
|||
|
|
"escape_char": "\\",
|
|||
|
|
"skip_rows": 1,
|
|||
|
|
"has_header": true,
|
|||
|
|
"null_values": ["", "NULL", "null", "N/A"]
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
#### Варианты формата JSON
|
|||
|
|
```json
|
|||
|
|
{
|
|||
|
|
"format": {
|
|||
|
|
"type": "json",
|
|||
|
|
"options": {
|
|||
|
|
"root_path": "$.data",
|
|||
|
|
"array_mode": "records|single",
|
|||
|
|
"flatten": false
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
#### Варианты формата XML
|
|||
|
|
```json
|
|||
|
|
{
|
|||
|
|
"format": {
|
|||
|
|
"type": "xml",
|
|||
|
|
"options": {
|
|||
|
|
"root_element": "//records/record",
|
|||
|
|
"namespaces": {
|
|||
|
|
"ns": "http://example.com/namespace"
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### Глобальные настройки
|
|||
|
|
|
|||
|
|
Определите таблицы поиска, переменные и глобальную конфигурацию:
|
|||
|
|
|
|||
|
|
```json
|
|||
|
|
{
|
|||
|
|
"globals": {
|
|||
|
|
"variables": {
|
|||
|
|
"current_date": "2024-01-01",
|
|||
|
|
"batch_id": "BATCH_001",
|
|||
|
|
"default_confidence": 0.8
|
|||
|
|
},
|
|||
|
|
"lookup_tables": {
|
|||
|
|
"country_codes": {
|
|||
|
|
"US": "United States",
|
|||
|
|
"UK": "United Kingdom",
|
|||
|
|
"CA": "Canada"
|
|||
|
|
},
|
|||
|
|
"status_mapping": {
|
|||
|
|
"1": "active",
|
|||
|
|
"0": "inactive"
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
"constants": {
|
|||
|
|
"source_system": "legacy_crm",
|
|||
|
|
"import_type": "full"
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### Отображение полей
|
|||
|
|
|
|||
|
|
Определите, как исходные данные сопоставляются с целевыми полями с использованием преобразований:
|
|||
|
|
|
|||
|
|
```json
|
|||
|
|
{
|
|||
|
|
"mappings": [
|
|||
|
|
{
|
|||
|
|
"target_field": "person_name",
|
|||
|
|
"source": "$.name",
|
|||
|
|
"transforms": [
|
|||
|
|
{"type": "trim"},
|
|||
|
|
{"type": "title_case"},
|
|||
|
|
{"type": "required"}
|
|||
|
|
],
|
|||
|
|
"validation": [
|
|||
|
|
{"type": "min_length", "value": 2},
|
|||
|
|
{"type": "max_length", "value": 100},
|
|||
|
|
{"type": "pattern", "value": "^[A-Za-z\\s]+$"}
|
|||
|
|
]
|
|||
|
|
},
|
|||
|
|
{
|
|||
|
|
"target_field": "age",
|
|||
|
|
"source": "$.age",
|
|||
|
|
"transforms": [
|
|||
|
|
{"type": "to_int"},
|
|||
|
|
{"type": "default", "value": 0}
|
|||
|
|
],
|
|||
|
|
"validation": [
|
|||
|
|
{"type": "range", "min": 0, "max": 150}
|
|||
|
|
]
|
|||
|
|
},
|
|||
|
|
{
|
|||
|
|
"target_field": "country",
|
|||
|
|
"source": "$.country_code",
|
|||
|
|
"transforms": [
|
|||
|
|
{"type": "lookup", "table": "country_codes"},
|
|||
|
|
{"type": "default", "value": "Unknown"}
|
|||
|
|
]
|
|||
|
|
}
|
|||
|
|
]
|
|||
|
|
}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### Типы преобразований
|
|||
|
|
|
|||
|
|
Доступные функции преобразования:
|
|||
|
|
|
|||
|
|
#### Преобразования строк
|
|||
|
|
```json
|
|||
|
|
{"type": "trim"},
|
|||
|
|
{"type": "upper"},
|
|||
|
|
{"type": "lower"},
|
|||
|
|
{"type": "title_case"},
|
|||
|
|
{"type": "replace", "pattern": "old", "replacement": "new"},
|
|||
|
|
{"type": "regex_replace", "pattern": "\\d+", "replacement": "XXX"},
|
|||
|
|
{"type": "substring", "start": 0, "end": 10},
|
|||
|
|
{"type": "pad_left", "length": 10, "char": "0"}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
#### Преобразования типов
|
|||
|
|
```json
|
|||
|
|
{"type": "to_string"},
|
|||
|
|
{"type": "to_int"},
|
|||
|
|
{"type": "to_float"},
|
|||
|
|
{"type": "to_bool"},
|
|||
|
|
{"type": "to_date", "format": "YYYY-MM-DD"},
|
|||
|
|
{"type": "parse_json"}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
#### Операции с данными
|
|||
|
|
```json
|
|||
|
|
{"type": "default", "value": "default_value"},
|
|||
|
|
{"type": "lookup", "table": "table_name"},
|
|||
|
|
{"type": "concat", "values": ["field1", " - ", "field2"]},
|
|||
|
|
{"type": "calculate", "expression": "${field1} + ${field2}"},
|
|||
|
|
{"type": "conditional", "condition": "${age} > 18", "true_value": "adult", "false_value": "minor"}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### Правила проверки
|
|||
|
|
|
|||
|
|
Проверки качества данных с настраиваемой обработкой ошибок:
|
|||
|
|
|
|||
|
|
#### Базовые проверки
|
|||
|
|
```json
|
|||
|
|
{"type": "required"},
|
|||
|
|
{"type": "not_null"},
|
|||
|
|
{"type": "min_length", "value": 5},
|
|||
|
|
{"type": "max_length", "value": 100},
|
|||
|
|
{"type": "range", "min": 0, "max": 1000},
|
|||
|
|
{"type": "pattern", "value": "^[A-Z]{2,3}$"},
|
|||
|
|
{"type": "in_list", "values": ["active", "inactive", "pending"]}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
#### Пользовательские проверки
|
|||
|
|
```json
|
|||
|
|
{
|
|||
|
|
"type": "custom",
|
|||
|
|
"expression": "${age} >= 18 && ${country} == 'US'",
|
|||
|
|
"message": "Must be 18+ and in US"
|
|||
|
|
},
|
|||
|
|
{
|
|||
|
|
"type": "cross_field",
|
|||
|
|
"fields": ["start_date", "end_date"],
|
|||
|
|
"expression": "${start_date} < ${end_date}",
|
|||
|
|
"message": "Start date must be before end date"
|
|||
|
|
}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### Предварительная обработка и постобработка
|
|||
|
|
|
|||
|
|
Глобальные операции, применяемые до/после сопоставления полей:
|
|||
|
|
|
|||
|
|
```json
|
|||
|
|
{
|
|||
|
|
"preprocessing": [
|
|||
|
|
{
|
|||
|
|
"type": "filter",
|
|||
|
|
"condition": "${status} != 'deleted'"
|
|||
|
|
},
|
|||
|
|
{
|
|||
|
|
"type": "sort",
|
|||
|
|
"field": "created_date",
|
|||
|
|
"order": "asc"
|
|||
|
|
}
|
|||
|
|
],
|
|||
|
|
"postprocessing": [
|
|||
|
|
{
|
|||
|
|
"type": "deduplicate",
|
|||
|
|
"key_fields": ["email", "phone"]
|
|||
|
|
},
|
|||
|
|
{
|
|||
|
|
"type": "aggregate",
|
|||
|
|
"group_by": ["country"],
|
|||
|
|
"functions": {
|
|||
|
|
"total_count": {"type": "count"},
|
|||
|
|
"avg_age": {"type": "avg", "field": "age"}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
]
|
|||
|
|
}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### Настройка вывода
|
|||
|
|
|
|||
|
|
Определите, как обработанные данные должны быть выведены:
|
|||
|
|
|
|||
|
|
```json
|
|||
|
|
{
|
|||
|
|
"output": {
|
|||
|
|
"format": "trustgraph-objects",
|
|||
|
|
"schema_name": "person",
|
|||
|
|
"options": {
|
|||
|
|
"batch_size": 1000,
|
|||
|
|
"confidence": 0.9,
|
|||
|
|
"source_span_field": "raw_text",
|
|||
|
|
"metadata": {
|
|||
|
|
"source": "crm_import",
|
|||
|
|
"version": "1.0"
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
"error_handling": {
|
|||
|
|
"on_validation_error": "skip|fail|log",
|
|||
|
|
"on_transform_error": "skip|fail|default",
|
|||
|
|
"max_errors": 100,
|
|||
|
|
"error_output": "errors.json"
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## Полный пример
|
|||
|
|
|
|||
|
|
```json
|
|||
|
|
{
|
|||
|
|
"version": "1.0",
|
|||
|
|
"metadata": {
|
|||
|
|
"name": "Customer Import from CRM CSV",
|
|||
|
|
"description": "Imports customer data from legacy CRM system",
|
|||
|
|
"author": "Data Team",
|
|||
|
|
"created": "2024-01-01T00:00:00Z"
|
|||
|
|
},
|
|||
|
|
"format": {
|
|||
|
|
"type": "csv",
|
|||
|
|
"encoding": "utf-8",
|
|||
|
|
"options": {
|
|||
|
|
"delimiter": ",",
|
|||
|
|
"has_header": true,
|
|||
|
|
"skip_rows": 1
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
"globals": {
|
|||
|
|
"variables": {
|
|||
|
|
"import_date": "2024-01-01",
|
|||
|
|
"default_confidence": 0.85
|
|||
|
|
},
|
|||
|
|
"lookup_tables": {
|
|||
|
|
"country_codes": {
|
|||
|
|
"US": "United States",
|
|||
|
|
"CA": "Canada",
|
|||
|
|
"UK": "United Kingdom"
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
"preprocessing": [
|
|||
|
|
{
|
|||
|
|
"type": "filter",
|
|||
|
|
"condition": "${status} == 'active'"
|
|||
|
|
}
|
|||
|
|
],
|
|||
|
|
"mappings": [
|
|||
|
|
{
|
|||
|
|
"target_field": "full_name",
|
|||
|
|
"source": "customer_name",
|
|||
|
|
"transforms": [
|
|||
|
|
{"type": "trim"},
|
|||
|
|
{"type": "title_case"}
|
|||
|
|
],
|
|||
|
|
"validation": [
|
|||
|
|
{"type": "required"},
|
|||
|
|
{"type": "min_length", "value": 2}
|
|||
|
|
]
|
|||
|
|
},
|
|||
|
|
{
|
|||
|
|
"target_field": "email",
|
|||
|
|
"source": "email_address",
|
|||
|
|
"transforms": [
|
|||
|
|
{"type": "trim"},
|
|||
|
|
{"type": "lower"}
|
|||
|
|
],
|
|||
|
|
"validation": [
|
|||
|
|
{"type": "pattern", "value": "^[\\w.-]+@[\\w.-]+\\.[a-zA-Z]{2,}$"}
|
|||
|
|
]
|
|||
|
|
},
|
|||
|
|
{
|
|||
|
|
"target_field": "age",
|
|||
|
|
"source": "age",
|
|||
|
|
"transforms": [
|
|||
|
|
{"type": "to_int"},
|
|||
|
|
{"type": "default", "value": 0}
|
|||
|
|
],
|
|||
|
|
"validation": [
|
|||
|
|
{"type": "range", "min": 0, "max": 120}
|
|||
|
|
]
|
|||
|
|
},
|
|||
|
|
{
|
|||
|
|
"target_field": "country",
|
|||
|
|
"source": "country_code",
|
|||
|
|
"transforms": [
|
|||
|
|
{"type": "lookup", "table": "country_codes"},
|
|||
|
|
{"type": "default", "value": "Unknown"}
|
|||
|
|
]
|
|||
|
|
}
|
|||
|
|
],
|
|||
|
|
"output": {
|
|||
|
|
"format": "trustgraph-objects",
|
|||
|
|
"schema_name": "customer",
|
|||
|
|
"options": {
|
|||
|
|
"confidence": "${default_confidence}",
|
|||
|
|
"batch_size": 500
|
|||
|
|
},
|
|||
|
|
"error_handling": {
|
|||
|
|
"on_validation_error": "log",
|
|||
|
|
"max_errors": 50
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## Подсказка для LLM для генерации описаний
|
|||
|
|
|
|||
|
|
Следующую подсказку можно использовать, чтобы LLM проанализировал примеры данных и сгенерировал конфигурацию описания:
|
|||
|
|
|
|||
|
|
```
|
|||
|
|
I need you to analyze the provided data sample and create a Structured Data Descriptor configuration in JSON format.
|
|||
|
|
|
|||
|
|
The descriptor should follow this specification:
|
|||
|
|
- version: "1.0"
|
|||
|
|
- metadata: Configuration name, description, author, and creation date
|
|||
|
|
- format: Input format type and parsing options
|
|||
|
|
- globals: Variables, lookup tables, and constants
|
|||
|
|
- preprocessing: Filters and transformations applied before mapping
|
|||
|
|
- mappings: Field-by-field mapping from source to target with transformations and validations
|
|||
|
|
- postprocessing: Operations like deduplication or aggregation
|
|||
|
|
- output: Target format and error handling configuration
|
|||
|
|
|
|||
|
|
ANALYZE THE DATA:
|
|||
|
|
1. Identify the format (CSV, JSON, XML, etc.)
|
|||
|
|
2. Detect delimiters, encodings, and structure
|
|||
|
|
3. Find data types for each field
|
|||
|
|
4. Identify patterns and constraints
|
|||
|
|
5. Look for fields that need cleaning or transformation
|
|||
|
|
6. Find relationships between fields
|
|||
|
|
7. Identify lookup opportunities (codes that map to values)
|
|||
|
|
8. Detect required vs optional fields
|
|||
|
|
|
|||
|
|
CREATE THE DESCRIPTOR:
|
|||
|
|
For each field in the sample data:
|
|||
|
|
- Map it to an appropriate target field name
|
|||
|
|
- Add necessary transformations (trim, case conversion, type casting)
|
|||
|
|
- Include appropriate validations (required, patterns, ranges)
|
|||
|
|
- Set defaults for missing values
|
|||
|
|
|
|||
|
|
Include preprocessing if needed:
|
|||
|
|
- Filters to exclude invalid records
|
|||
|
|
- Sorting requirements
|
|||
|
|
|
|||
|
|
Include postprocessing if beneficial:
|
|||
|
|
- Deduplication on key fields
|
|||
|
|
- Aggregation for summary data
|
|||
|
|
|
|||
|
|
Configure output for TrustGraph:
|
|||
|
|
- format: "trustgraph-objects"
|
|||
|
|
- schema_name: Based on the data entity type
|
|||
|
|
- Appropriate error handling
|
|||
|
|
|
|||
|
|
DATA SAMPLE:
|
|||
|
|
[Insert data sample here]
|
|||
|
|
|
|||
|
|
ADDITIONAL CONTEXT (optional):
|
|||
|
|
- Target schema name: [if known]
|
|||
|
|
- Business rules: [any specific requirements]
|
|||
|
|
- Data quality issues to address: [known problems]
|
|||
|
|
|
|||
|
|
Generate a complete, valid Structured Data Descriptor configuration that will properly import this data into TrustGraph. Include comments explaining key decisions.
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### Пример использования запроса
|
|||
|
|
|
|||
|
|
```
|
|||
|
|
I need you to analyze the provided data sample and create a Structured Data Descriptor configuration in JSON format.
|
|||
|
|
|
|||
|
|
[Standard instructions from above...]
|
|||
|
|
|
|||
|
|
DATA SAMPLE:
|
|||
|
|
```csv
|
|||
|
|
CustomerID,Имя,Электронная почта,Возраст,Страна,Статус,Дата присоединения,Общая сумма покупок
|
|||
|
|
1001,"Smith, John",john.smith@email.com,35,US,1,2023-01-15,5420.50
|
|||
|
|
1002,"doe, jane",JANE.DOE@GMAIL.COM,28,CA,1,2023-03-22,3200.00
|
|||
|
|
1003,"Bob Johnson",bob@,62,UK,0,2022-11-01,0
|
|||
|
|
1004,"Alice Chen","alice.chen@company.org",41,US,1,2023-06-10,8900.25
|
|||
|
|
1005,,invalid-email,25,XX,1,2024-01-01,100
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
ADDITIONAL CONTEXT:
|
|||
|
|
- Target schema name: customer
|
|||
|
|
- Business rules: Email should be valid and lowercase, names should be title case
|
|||
|
|
- Data quality issues: Some emails are invalid, some names are missing, country codes need mapping
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### Запрос на анализ существующих данных без использования образцов
|
|||
|
|
|
|||
|
|
```
|
|||
|
|
I need you to help me create a Structured Data Descriptor configuration for importing [data type] data.
|
|||
|
|
|
|||
|
|
The source data has these characteristics:
|
|||
|
|
- Format: [CSV/JSON/XML/etc]
|
|||
|
|
- Fields: [list the fields]
|
|||
|
|
- Data quality issues: [describe any known issues]
|
|||
|
|
- Volume: [approximate number of records]
|
|||
|
|
|
|||
|
|
Requirements:
|
|||
|
|
- [List any specific transformation needs]
|
|||
|
|
- [List any validation requirements]
|
|||
|
|
- [List any business rules]
|
|||
|
|
|
|||
|
|
Please generate a Structured Data Descriptor configuration that will:
|
|||
|
|
1. Parse the input format correctly
|
|||
|
|
2. Clean and standardize the data
|
|||
|
|
3. Validate according to the requirements
|
|||
|
|
4. Handle errors gracefully
|
|||
|
|
5. Output in TrustGraph ExtractedObject format
|
|||
|
|
|
|||
|
|
Focus on making the configuration robust and reusable.
|
|||
|
|
```
|