data:image/s3,"s3://crabby-images/14454/144541da17469fb67bb6998e91e8d8e984df84ea" alt="azblob://2023/11/04/eyecatch/2023-11-04-power-automate-and-azure-functions-char-width-converter-000.jpg"
こんにちは、あおいです。
昨夜、新宿ゴールデン街のBarで初めて飲みました!とてもディープな街で楽しかったです(笑)
さて、Power Automateで半角⇔全角の変換処理をする場合、Replace関数で地道に対象の文字列を置換したり、Excel Onlineで変換表を用意して置換したりするなど様々な方法があります。しかし、この手の変換処理はノーコード・ローコードにとって不向きな分野です。あまりにも労力がかかりすぎるため、Azure Functionsで半角⇔全角の変換処理をコード化し、[HTTP]アクションでその処理を呼び出すのがベストプラクティスです。
そこで、今回はPower AutomateとAzure Functionsで半角⇔全角の変換をする方法について紹介したいと思います。
[Microsoft Azure portal]にサインイン後、[関数アプリ]で基本情報を設定して[確認および作成]をクリックします。今回の言語は「Node.js」、リージョンは「Japan East」を選択します。
data:image/s3,"s3://crabby-images/ee764/ee76490f91dbd122f4d81017b2996ea6d3cc78eb" alt=""
デプロイ完了後、関数の作成をします。[HTTP]アクションで呼び出す想定なので、トリガーは[HTTP trigger]を選択します。テンプレートの詳細で関数名を「CharWidthConverter」と入力し、Authorization level(認証)は Anonymousを選択して[作成]をクリックします。
data:image/s3,"s3://crabby-images/5c4aa/5c4aa64bcd075c28ea95eaf8ffaa6701879c68b3" alt=""
[コードとテスト]で以下のコードを記述し、[保存]をクリックします。[テストと実行]で想定通りの挙動を示すか事前に検証しておくことを推奨します。
Javascriptmodule.exports = async function (context, req) {
if(req.body.key == "toFullWidth") {
response = convertToFullWidth(req.body.value);
}else if(req.body.key == "toHalfWidth") {
response = convertToHalfWidth(req.body.value);
}
context.res = {
body: response
};
}
// 半角→全角
function convertToFullWidth(value) {
if (typeof value !== 'string') return value;
return String(value).replace(/[!-~]/g, function(all) {
return String.fromCharCode(all.charCodeAt(0) + 0xFEE0);
});
};
// 全角→半角
function convertToHalfWidth(value) {
if (!value) return value;
return String(value).replace(/[!-~]/g, function(all) {
return String.fromCharCode(all.charCodeAt(0) - 0xFEE0);
});
};
data:image/s3,"s3://crabby-images/728d5/728d5a18eeda868522d5158f4486bf03c0b9a4df" alt=""
[関数のURLの取得]をクリックし、URLをクリップボードにコピーします。
data:image/s3,"s3://crabby-images/2ff9d/2ff9d0c979c9eadc43a5414009b958f036f35efe" alt=""
あとは[HTTP]アクションで各項目を設定して呼び出すのみです。
data:image/s3,"s3://crabby-images/af513/af513de2b76575cacccb5cab6941a037922552f6" alt=""
動作確認でテスト実行すると、入力した文字列が正常に全角変換されています。
data:image/s3,"s3://crabby-images/f3193/f31938646c79000271a52c4e1492a8bc7b0f694d" alt=""
今回はPower AutomateとAzure Functionsで半角⇔全角の変換をする方法について紹介させていただきました。注意点として、本記事で扱ったコードは半角カタカナ⇔全角カタカナの変換には対応していませんので、別途コードの追記が必要になります。本記事が少しでも読者の皆様のお役に立てれば幸いです。