No.6ベストアンサー
- 回答日時:
> 具体的にどのようにやるんでしょうか?
置換の対象が「大字」みたいな2文字以上の文字列を含むかどうかで
全く違ってきます。
元のデータを「テーブル1」
置換用を「置換テーブル」
として読み込んであるものとして
let
置換テーブル = #table(type table[前=text, 後=text],{{" ",""},{"字",""},{"#(lf)",""},{"ケ","ケ"}}),
テーブル1 = #table(type table[名前=text], {{"あいう かきく さしす"},{"あいう えお字かきく"},{"あいうえお#(lf)かきくけこ"},{"あいうケえこケさし"}}),
値の置換 = Table.AddColumn(テーブル1, "変換後",
each List.Reverse(
List.Generate(
()=> [i=0, name=[名前]],
each [i] <= Table.RowCount(置換テーブル),
each [
i = [i]+1,
name = Text.Replace([name],置換テーブル{i-1}[前],置換テーブル{i-1}[後])
],
each [name]
)
){0},
type text
)
in
値の置換
1文字→1文字の置換でよければ Text.Splitで分割したものを置換して
から結合しなおせばいいです。
No.8
- 回答日時:
こんばんは
当方Microsoft365ではなく2019のため、
No.7さんのレイアウトで配列数式版で考えてみました。
置換後はテーブルではなく、CHOOSE関数を使用している関係上、
$E$3,$E$4,$E$5,$E$6とダイレクトにセル指定する必要があります。
置換後の空欄セルは ="" でセットしてください。
ご参考です。
{=CONCAT(
IFERROR(
CHOOSE(
IFERROR(
MATCH(MID(A6,ROW(OFFSET($A$1,,,LEN(A6))),1),$D$3:$D
$6,0),
LEN(A6)+1),
$E$3,$E$4,$E$5,$E$6),
MID(A6,ROW(OFFSET($A$1,,,LEN(A6))),1))
)}
No.7
- 回答日時:
Microsoft365みたいなので一応 数式も載せておきます。
画像右のように置換テーブルを作成しておいて
B3に
=LET(_rng,[@名前],_rws,ROWS(置換テーブル[前]),INDEX(SCAN([@名前],SEQUENCE(_rws),LAMBDA(a,b,SUBSTITUTE(a,INDEX(置換テーブル[前],b),INDEX(置換テーブル[後],b)))),_rws))
No.5
- 回答日時:
> 一つ一つ、複数のSUBSTITUTEでくくりながら長い数式を書くしか
> ないでしょうか?
「数式でやる場合」ですか? バージョンによります。
LAMBDA関数が使えるなら再帰処理が可能です。
古いバージョンの場合は循環参照で反復計算させればできます。
個人的にはお勧めしません。
マクロでやれば当然できますが 置換の対応表があるならクエリでやっ
てもいいように思います。
ありがとうございます。
こちらOffice365なので最新です。
「LAMBDA関数」最近別件で耳にしましたので興味があります。
しかし本件はお勧めしないやり方なんですね。。。
> 置換の対応表があるならクエリで
具体的にどのようにやるんでしょうか?
・半角スペースを削除
・”字”を削除
・改行コードを削除
・”ケ”を”ケ”に置換
こういった複数条件を対応表にして実現できますか?
No.4
- 回答日時:
VBAで以下のようなコードを書くと、置換ができます。
Sub Main
Dim MotoText() As Variant, SakiTest() as Variant
Dim i As Integer
MotoText = Array(" ", "字", Chr(10), "ケ")
SakiText = Array("", "", "", "ケ")
Range("B1:B10") = Range("A1:A10")
For i = 0 To UBound(MotoText)
Range("B1:B10").Replace What:=MotoText(i), replacement:=SakiText(i)
Next i
End Sub
ありがとうございます。その方法だと複数の条件を併記すれば拡張性ありますね。
ネックと言えば一度実行すると履歴を辿って元に戻せない事ですね。
方法を考えて活用したいと思います。
No.3
- 回答日時:
こんにちは
置換の組み合わせの種類がいろいろあるような場合は、あまり有効ではありませんけれど・・
組み合わせ種類が少なければ、ユーザ定義関数にしておいて、それを利用するとか。
やっている内容は変わらないので処理としてはメリットはありませんけれど、セル内の関数式を単純化できるというメリットはあるでしょう。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 特定の文字を簡単な操作で半角スペースに変換するか削除したい 2 2022/11/01 10:35
- Excel(エクセル) PowerQueryに詳しい方教えてください(Office365) 1 2022/07/24 21:11
- Visual Basic(VBA) EXCEL VBA 単語置き換え について質問です ブック名 ぶぶぶ シート名 ししし セル V3〜 3 2023/03/08 01:41
- Excel(エクセル) VBA 文字列変換と指定した列にある日時データから時間を削除する方法について 2 2022/04/14 15:23
- Excel(エクセル) Excel 散布図グラフ 外れ値 セル番地参照方法 4 2022/04/19 18:56
- Excel(エクセル) Excelの関数で実現可能か知りたいです 5 2023/08/06 08:58
- Excel(エクセル) Excel 指定した固有番号で、複数の行を削除する方法は? 2 2022/03/30 15:18
- Excel(エクセル) substitute関数についての質問です 3 2023/06/21 11:57
- Excel(エクセル) VBA 指定した列にある日時データから時間を削除する方法について 4 2022/04/14 11:17
- Access(アクセス) Access2016でフォーム内にExcelの複数シートを 表示させるイメージで複数テーブルの デー 1 2022/11/25 15:30
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
エクセルの関数SUBSTITUTEを、複数の条件を簡単に書く方法
Excel(エクセル)
-
Excelの関数 SUBSTITUTEとIF関数の組み合わせについて
Excel(エクセル)
-
【Excel関数】特定の文字を別表のリストの文字に変換したい
Excel(エクセル)
-
-
4
EXCEL VBA セルに既に入力されている文字に文字を追加する
Excel(エクセル)
-
5
Excel2007でカタカナの文字のみを抽出、表示するには?
その他(Microsoft Office)
-
6
Excelでカタカナ・ひらがな・英数字の抽出
その他(Microsoft Office)
-
7
複数の文字列のいずれかが含まれていたらTRUEを返す関数について
Excel(エクセル)
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルの関数について教えて...
-
Excelカスタム関数(アドイン登...
-
Excelデータをコピペして、ペー...
-
Excel関数-文字列で自動作成さ...
-
スプレッドシート、Excelでの数...
-
Excelで50個のセルに同じ文字を...
-
Microsoft Officeの中古は信用...
-
スプレッドシートで使う数式を...
-
エクセルVBA、別ブックへ転記す...
-
エクセルで会社の従業員のデー...
-
エクセルで不等号記号(≠)が上に...
-
エクセルの表で1年間の曜日を...
-
A列とB列を参照してC列に連番を...
-
エクセルの空欄をつめて、次の...
-
エクセルでの特別な文字を上に...
-
エクセルでセルに標準で入力さ...
-
エクセル日付 文字列の関数がエ...
-
エクセル2013で月間勤務表から...
-
エクセルの日付を編集する
-
EXCELの質問です 119から足した...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルVBA、別ブックへ転記す...
-
エクセルでの作業計算方法について
-
時間によってファイル名が変わ...
-
【関数】適切な文字数の数字を...
-
Excelについて教えてください
-
エクセル初心者です 関数の入れ...
-
【マクロ】ファイル名の変更に...
-
UNIQUE関数が使えないバージョ...
-
エクセルの計算
-
【関数】先頭だけにある、半角...
-
Excelで、決まった行を繰り返し...
-
Excelでセルの値が同じか...
-
LOOKUP関数を使えばいいのでし...
-
Excel
-
はがきについて。
-
エクセルの条件付き書式につい...
-
エクセルのデーターが2か月前の...
-
エクセル②
-
エクセルで「-0.0」と表示さ...
-
Microsoft1Officeの互換ソフト...
おすすめ情報