Разбор текста в приложениях логики Azure

Я хочу создать приложение Azure Logic, которое будет постоянно запрашивать определенный веб-сайт в Интернете и анализировать полученный HTML.

Я создал приложение логики и настроил интервал и действие HTTP-запроса.

Какое действие я должен выбрать в качестве следующего шага для простой операции регулярного выражения в HTML-коде?

Мне приходит в голову создание функции Azure, которая будет выполнять эту работу, но мне интересно, есть ли другое решение, более подходящее для такой задачи.

Я хочу, чтобы это было как можно проще.


Редактировать:

Просто обнаружил какую-то классную особенность. Приложения логики содержат некоторые базовые выражения для примитивных типов.

К сожалению, ему не хватает каких-либо regex или же string.contains,

Сейчас я попробую с функциями Azure.

4 ответа

Решение

Мне удалось решить мою проблему с использованием языка определения рабочих процессов и стандартных блоков, предоставляемых Azure.

Идея Azure Function была не такой уж плохой, и она идеально подходила бы для любого более сложного случая, но, как я уже упоминал, я хотел, чтобы это было как можно проще, поэтому вот оно.

Вот так теперь выглядит мой поток.

Для полноты, вот поток в формате JSON

{
    "$connections": {
        "value": {
            "wunderlist": {
                "connectionId": "/subscriptions/.../providers/Microsoft.Web/connections/wunderlist",
                "connectionName": "wunderlist",
                "id": "/subscriptions/.../providers/Microsoft.Web/locations/northeurope/managedApis/wunderlist"
            }
        }
    },
    "definition": {
        "$schema": "https://schema.management.azure.com/providers/Microsoft.Logic/schemas/2016-06-01/workflowdefinition.json#",
        "actions": {
            "Condition": {
                "actions": {
                    "Create_a_task": {
                        "inputs": {
                            "body": {
                                "completed": false,
                                "list_id": 000000000,
                                "starred": true,
                                "title": "@{variables('today date')}"
                            },
                            "host": {
                                "connection": {
                                    "name": "@parameters('$connections')['wunderlist']['connectionId']"
                                }
                            },
                            "method": "post",
                            "path": "/tasks",
                            "retryPolicy": {
                                "type": "none"
                            }
                        },
                        "limit": {
                            "timeout": "PT20S"
                        },
                        "runAfter": {},
                        "type": "ApiConnection"
                    },
                    "Set_a_reminder": {
                        "inputs": {
                            "body": {
                                "date": "@{addHours(utcNow(), 3)}",
                                "list_id": 000000,
                                "task_id": "@body('Create_a_task')?.id"
                            },
                            "host": {
                                "connection": {
                                    "name": "@parameters('$connections')['wunderlist']['connectionId']"
                                }
                            },
                            "method": "post",
                            "path": "/reminders",
                            "retryPolicy": {
                                "type": "none"
                            }
                        },
                        "limit": {
                            "timeout": "PT20S"
                        },
                        "runAfter": {
                            "Create_a_task": [
                                "Succeeded"
                            ]
                        },
                        "type": "ApiConnection"
                    }
                },
                "expression": "@contains(body('HTTP'), variables('today date'))",
                "runAfter": {
                    "Initialize_variable": [
                        "Succeeded"
                    ]
                },
                "type": "If"
            },
            "HTTP": {
                "inputs": {
                    "method": "GET",
                    "uri": "..."
                },
                "runAfter": {},
                "type": "Http"
            },
            "Initialize_variable": {
                "inputs": {
                    "variables": [
                        {
                            "name": "today date",
                            "type": "String",
                            "value": "@{utcNow('yyyy/MM/dd')}"
                        }
                    ]
                },
                "runAfter": {
                    "HTTP": [
                        "Succeeded"
                    ]
                },
                "type": "InitializeVariable"
            }
        },
        "contentVersion": "1.0.0.0",
        "outputs": {},
        "parameters": {
            "$connections": {
                "defaultValue": {},
                "type": "Object"
            }
        },
        "triggers": {
            "Recurrence": {
                "recurrence": {
                    "frequency": "Day",
                    "interval": 1,
                    "startTime": "2017-08-01T23:55:00Z",
                    "timeZone": "UTC"
                },
                "type": "Recurrence"
            }
        }
    }
}

Вы можете использовать действие встроенного кода в приложении логики для запуска кода регулярного выражения javascript (предварительная версия - май 2019 г.) (не поддерживается в Flow).

Код Iniline

Ссылка на встроенный код приложения логики

Создайте функцию Azure в соответствии с:

{

log.Info ("Триггерная функция C# HTTP обработала запрос.");

// Get request body

dynamic data = await req.Content.ReadAsAsync<object>();



// Set name to query string or body data

string input = data?.input.ToString();

var regexJson = data?.regexList;

var regexes = regexJson.ToObject<List<RegexReplace>>();



foreach (var regex in regexes) 

{

    var re = Regex.Replace(regex.Regex, "\\\\","\\");

    var replace = Regex.Replace(regex.Replace, "\\\\","\\");

    input = Regex.Replace(input, "\\\"","\"");

    input = Regex.Replace(input, re, replace);

}



input = Regex.Replace(input, "[\\r\\n]", "");



return data.regexList == null

    ? req.CreateResponse(HttpStatusCode.BadRequest, "Please pass a name on the query string or in the request body")

    : req.CreateResponse(HttpStatusCode.OK, input, "application/json");

}

открытый класс RegexReplace

{

public string Regex { get; set; }

public string Replace { get; set; }

}

Это моя функция для замены текста в строке. это можно использовать повторно, и этот подход можно использовать для многих схожих аспектов работы в приложениях логики:

using System.Net;

public static async Task<HttpResponseMessage> Run(HttpRequestMessage req, TraceWriter log)
{
    dynamic data = await req.Content.ReadAsAsync<object>();
    string removeme = data?.removeme;
    string replacewith = data?.replacewith;
    string value = data?.value;

    return req.CreateResponse(HttpStatusCode.OK, value.Replace(removeme, replacewith));
}

Затем я бы опубликовал такой объект из моего приложения логики:

{
    "removeme": "SKU-",
    "replacewith": "P-",
    "value": "SKU-37378633"
}

... чтобы получить результат: "P-37378633"

Вы, вероятно, на правильном пути. Функция Azure была бы наиболее подходящим способом реализовать это прямо сейчас. Приложение API - это вариант, но это более тяжелая платформа, чем вам нужно.

Другие вопросы по тегам