Search code examples
csvexport-to-csvazure-logic-apps

Remove blank column in CSV with Azure Logic App


I have a CSV file on a SFTP which has 13 columns, but annoyingly the last one has no data or header, so basically there is an extra comma at the end of every record:

PGR,Concession ,Branch ,Branch Name ,Date ,Receipt ,Ref/EAN,Till No ,Qty , Price  , Discount , Net Price  ,

I want to use Logic App to remove the last 13th column and resave the file in a BLOB storage. I've got as far as reading the file from SFTP and storing the entire text in a variable, then using select to get only the columns I need, but beyond that I can't work out how to export all the records onto 1 clean csv file in BLOB.

enter image description here

enter image description here


Solution

  • You'll need to process each row in the array and remove the last comma one by one. As you remove it, add the result to a new array variable. This is the basis of the flow ...

    Flow

    This expression is the main worker and it's the thing that will remove the last character of each row ...

    substring(items('For_each'), 0, add(length(items('For_each')), -1))
    

    Before

    Before

    After

    After

    This is the definition of the Logic App. Drop it in to your tenant and see how it works.

    {
        "definition": {
            "$schema": "https://schema.management.azure.com/providers/Microsoft.Logic/schemas/2016-06-01/workflowdefinition.json#",
            "actions": {
                "For_each": {
                    "actions": {
                        "Append_to_string_variable": {
                            "inputs": {
                                "name": "Result String",
                                "value": "@if(equals(length(items('For_each')), 0), '', concat(substring(items('For_each'), 0, add(length(items('For_each')), -1)), '\r\n'))"
                            },
                            "runAfter": {},
                            "type": "AppendToStringVariable"
                        }
                    },
                    "foreach": "@variables('CSV Data')",
                    "runAfter": {
                        "Initialize_Result_String": [
                            "Succeeded"
                        ]
                    },
                    "runtimeConfiguration": {
                        "concurrency": {
                            "repetitions": 1
                        }
                    },
                    "type": "Foreach"
                },
                "Initialize_CSV_Data": {
                    "inputs": {
                        "variables": [
                            {
                                "name": "CSV Data",
                                "type": "array",
                                "value": [
                                    "Header1,Header2,Header3,",
                                    "Test1.1,Test1.2,Test1.3,",
                                    "Test2.1,Test2.2,Test2.3,",
                                    "",
                                    "Test3.1,Test3.2,Test3.3,",
                                    ""
                                ]
                            }
                        ]
                    },
                    "runAfter": {},
                    "type": "InitializeVariable"
                },
                "Initialize_Cleansed_CSV_Data": {
                    "inputs": {
                        "variables": [
                            {
                                "name": "Cleansed CSV Data",
                                "type": "array"
                            }
                        ]
                    },
                    "runAfter": {
                        "Initialize_CSV_Data": [
                            "Succeeded"
                        ]
                    },
                    "type": "InitializeVariable"
                },
                "Initialize_Result_String": {
                    "inputs": {
                        "variables": [
                            {
                                "name": "Result String",
                                "type": "string"
                            }
                        ]
                    },
                    "runAfter": {
                        "Initialize_Cleansed_CSV_Data": [
                            "Succeeded"
                        ]
                    },
                    "type": "InitializeVariable"
                },
                "Initialize_variable": {
                    "inputs": {
                        "variables": [
                            {
                                "name": "Result",
                                "type": "string",
                                "value": "@variables('Result String')"
                            }
                        ]
                    },
                    "runAfter": {
                        "For_each": [
                            "Succeeded"
                        ]
                    },
                    "type": "InitializeVariable"
                }
            },
            "contentVersion": "1.0.0.0",
            "outputs": {},
            "parameters": {},
            "triggers": {
                "Recurrence": {
                    "evaluatedRecurrence": {
                        "frequency": "Month",
                        "interval": 3
                    },
                    "recurrence": {
                        "frequency": "Month",
                        "interval": 3
                    },
                    "type": "Recurrence"
                }
            }
        },
        "parameters": {}
    }