Convert CSV file to JSON in Logic app.
This is the full step-by-step process, and I have provided its output below.
I used the below CSV file, separated by pipes ('|'), to test this.
Please follow the below steps.
Step 1: I fetched the file from Blob by searching for the blob and selecting the 'Get blob content' action.
data:image/s3,"s3://crabby-images/13f2c/13f2c48c9a9b6abd2865e1cc71a220c55c06b6c3" alt=""
Step 2: For this action, I provided the storage account name and file path.
data:image/s3,"s3://crabby-images/bc40c/bc40cc00df1c53a92c65be84af6c6e6c56189cec" alt=""
Step 3: To process the output content from the blob, I used the 'Compose' action and applied the 'Split' function.
data:image/s3,"s3://crabby-images/b137b/b137b69fa1a321382c74799b9ab9b33ecdb93ba4" alt=""
Expression:
split(body('Get_blob_content_'),decodeUriComponent('%0D%0A'))
data:image/s3,"s3://crabby-images/63cdb/63cdb8f58aae4a913e2d7e326027b4b62e273480" alt=""
Step 4: Additionally, I used another 'Compose' action to remove the last line, as it appeared empty. You can choose to include or omit this step based on your file structure.
Expression:
take(outputs('Split_by_line'),add(length(outputs('Split_by_line')),-1))
data:image/s3,"s3://crabby-images/facca/faccacf51dfa0119d20f94e693ff65ceef4ff838" alt=""
Step 5: Another 'Compose' action was selected to split the text data based on the separator '|'.
Expression:(separator '|')
split(first(outputs('Split_by_line')), '|')
Step 6: Under data operations, I chose 'Select.'
data:image/s3,"s3://crabby-images/36796/3679610d587a836b05a2df07e6126dd7d167d941" alt=""
- For the 'From' node, I used the specified expression
skip(outputs('Remove_last_line'), 1)
- For the 'Map' node, I used the provided expression. (separator '|')
Left Right
outputs('Fields')[0] --- split(item(), '|')?[0]
outputs('Fields')[1] --- split(item(), '|')?[1]
outputs('Fields')[2] --- split(item(), '|')?[2]
outputs('Fields')[3] --- split(item(), '|')?[3]
Step 7: Finally, I selected the 'Parse JSON' action and provided the content from the outputs of the 'Select' step.
data:image/s3,"s3://crabby-images/e675e/e675eeaa2cebcf93ba95a8e2e566aeea3252d809" alt=""
Outputs :
Step 2 output:
data:image/s3,"s3://crabby-images/1994e/1994e9f72b8e32c7a184cdcd60f3aa19c4bc56a2" alt=""
Step 3 Output :
data:image/s3,"s3://crabby-images/fe5cf/fe5cfc5cd9feac6f3bad319fbd9140d36d7e8e78" alt=""
Step 4 Output :
Step 5 Output :
data:image/s3,"s3://crabby-images/d16ec/d16ecca290e2fee2ab1f4a9a5c1100505ea16814" alt=""
Step 6 Output :
Step 7 Output :
data:image/s3,"s3://crabby-images/38d2a/38d2aef55bb66b13ea41426a4c25e2e997039590" alt=""
Reference: Link 1, Link 2
Keep Daxing!!