"Merge columns" node
This node allows you to create a new column based on the values from other columns and to define the separator between the merged values.
In the settings of this node, you must select the columns that will be merged. You can do this by:
- Selecting the column names.
- Creating a condition (referred to as a dynamic condition further in this article) that the column names must meet in order to be transformed, for example, the column name must start with the letter “A”.
Dynamic conditions are especially helpful when using a JSON file as a sample in the “Data Input” node. When a JSON file contains an object deeper than the root object, its items will be transferred to the Data Input node as separate columns named {object}.{parameter}
. When choosing columns manually, you can’t add those new columns from a JSON list to the transformation. Dynamic conditions can be set up to include those columns, for example by including columns whose name includes the name of the object they were created from.
Node configuration
data:image/s3,"s3://crabby-images/33490/33490b1416e20dbeb253ef312c939fbb72d5f7f7" alt="Merge column operation on an example file"
-
Click Add rule.
-
Select one of the Include options, by clicking the
icon next to these:
- these - the default; it lets you select the columns for merging.
- all except these - this option lets you select the columns which you do NOT want to merge. Values from all the other columns will be merged into a new column.
-
Select columns to include/exclude (according to the Include setting above) in one of the following ways:
- Select column - from the dropdown list, you can select the columns which will be included or excluded from the operation.
- Define conditions - you can create a dynamic condition which columns must meet to merge their values in a new column; for this purpose, you can use logical operators such as contain, starts with, ends with, and so on.
Important: You can’t combine dynamic conditions with the Include all except these option.
For further instructions, select one of the tabs below, depending on the option you have chosen in step 3.
Select column option - From the dropdown list, select the first column.
- To add more columns, click
icon and select the column from the list.
- In the New column name field, enter the name of the column that will be added.
- If you selected Include these at the beginning of the procedure, the new column will contain values from columns you selected for merging.
- If you selected Include all except these at the beginning of the procedure, the new column will contain values from all the other columns that you didn’t select.
- In the Separator field, enter the character which will function as a separator among values of the columns that are being merged.
-
Optionally, you can delete the original columns by enabling the Remove original columns option on.
-
You can check the preview of the file after changes in the Output data tab.
-
To define what happens if rows contain errors, select one of the options available in the Error handling section.
-
Confirm the settings by clicking Apply.
Handle errors
You can define what to do with failed values (for example, as a result of Jinja rendering or in other cases) in cells where data type modification failed. In the Error handling section, select one of the following options:
- Skip row if error occurred - It omits the row when an exception occurs.
- Skip if result is null or empty string - It omits rows with empty strings and
null
(which may be the result of rendering Jinja) - Stop further transformation - The transformation stops at the row with an error. The data before the line that caused the error is transformed (and imported if the transformation rule is used in the Data Transformation node).
- Insert null if error occurred - Wrong values are replaced with
null
. If you use such a transformation for the import of profiles, the existing value of an attribute is cleared and replaced with thenull
value. - Insert empty string if error occurred - Wrong value is removed and the cell remains empty.
Example of use
You can use the Merge columns node in order to create an event salt. Event salt allows you to avoid duplicating an entry in the database if it is imported more than once. It is especially useful while importing events to Synerise.
customId,orderId,paymentInfo,finalUnitPriceAmount,productQuantity,sku,eventTimestamp,productName,productPriceAmount
123345,448362,cash,13.35,1,642,13.02.2022,shoe1,13.35
123345,448362,cash,40,1,453,13.02.2022,shoe2,40
345678,45678990,online,13.99,1,726,13.02.2022,shoe3,13.99
- As the first node, add Data Input.
- In the configuration of the node, upload a file on which you want to perform data transformation.
- As the next node, add a Merge Columns node.
- In the configuration of the node:
- merge the orderId and eventTimestamp columns together,
- enter
eventSalt
as the name of the new column, - set
-
as a separator.
Configuration of the Merge columns node - Leave the rest of the settings at default.
- As the last node, add Data Output.
Result: You receive a data file with a new eventSalt column.