質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
Curl(プログラミング言語)

Curl(プログラミング言語)は、Webコンテンツ向けのプログラミング言語。HTMLのようなテキスト記述やレイアウトデザイン、JavaScript のようなオブジェクト指向プログラム言語、Java のような重量機能など複数の言語の特徴を一つのフレームワークに統合しています。

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

Q&A

1回答

1774閲覧

Googleスプレッドシートで、自動で全角数字を入力したものを半角数字に変換したいです。

fuyuse

総合スコア0

Curl(プログラミング言語)

Curl(プログラミング言語)は、Webコンテンツ向けのプログラミング言語。HTMLのようなテキスト記述やレイアウトデザイン、JavaScript のようなオブジェクト指向プログラム言語、Java のような重量機能など複数の言語の特徴を一つのフレームワークに統合しています。

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

0グッド

2クリップ

投稿2023/07/15 17:03

Googleスプレッドシートで、自動で全角数字を入力した際に半角数字にする方法を探しています。

いくつかネットの記事で調べ、GASにて試しましたが、上手く変換されずでした。
ここのサイトで類似質問が既出でしたが、そちらの方法は上手くいきました。

ただそちらの方法は、あるシートの、ある行という指定のコードでしたので、
私としては、全てのシート、全てのセルで適用させたいと考えております。全角数字を使うことがないためです。
(シート名は変更しているので、シート名に影響されないコードですと嬉しいです)

プログラミング自体、勉強始めたばかりで、GASも初めて触ったので、そこまで詳しくなく...
色々調べたり、コード入力もしてみましたが、お手上げ状態ですので、ご教示いただけますと助かります。
よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

YellowGreen

2023/07/15 22:10 編集

1) > ただそちらの方法は、あるシートの、ある行という指定のコードでしたので、 お試しいただいたスクリプトが示されていないので想像での質問になりますが、 そのスクリプトから if (...) { ... return; } や if (...) ... return; という条件での処理の行があるなら、それらを全てコメントにするか削除するとどうなりますか? または、 全角半角の変換処理が if(...) { ... 変換処理 ... } のように記述されているなら if (...) { の行を1行と エディタでif文の行末の{と対になっている { と同じ色の } の行を1行の 合わせて2行(if文が複数組み合わせてあるなら、同じように対になっている2行ずつ)を コメントか削除してみるとどうなりますか? 2) 全角半角変換をしたいのは数字だけで良いのですか? 小数点、コロン、スラッシュなどは、数字と一緒に入力されることが多いですが。
YAmaGNZ

2023/07/15 22:45 編集

この処理をどのような方法で実行しようと考えてますか? GASを使用せずに入力規則を設定することで半角数字のみ入力できるといった制限をかけることもできますし 計算させたいので半角数字でないとダメだということであれば、計算式にて全角半角を変換して計算するという手もあります。
winterboum

2023/07/15 23:22

勘違いを招く表現 「自動で全角数字を入力した」ものを半角数字に変換 とも 全角数字を入力したものを自動で半角数字に変換 とも この場合はまぁ文脈から推定できますが、こういう仕様書書いてると あら! ってことが起きますよ。
guest

回答1

0

想像でお答えします。
例えば、次のようなスクリプトをスクリプトエディタに保存しておくと、
入力またはペーストされた全角数字を自動で半角数字に置換します。
文字コードを変換することで半角数字にします。

入力のあったセル範囲を二次元の配列(values)に取得して
その配列の要素の値に全角数字があるとそれを全て半角数字に置換するという処理(.toString().replace(...))を
各行の要素(外側の配列:各要素をcellsとして処理)、各セルの要素(内側の配列:各要素をvとして処理)と
順次処理を適用した結果を配列として戻し(.map()は配列の各要素への処理結果を新たな配列として返します)、
元のセル範囲にその配列を記入します。
セル範囲が一つのセルのときでも[['セルの値']]という二次元配列として処理します。

サーバーとの通信で若干のタイムラグがあります。

JavaScript

1function onEdit() { 2 const range = SpreadsheetApp.getActiveSheet().getActiveRange(); 3 let values = range.getValues(); 4 // 全角数字を半角数字に置換 5 values = values.map(cells => cells.map(v => v.toString().replace(/[0-9]/g, s => String.fromCharCode(s.charCodeAt(0) - 0xFEE0)))); 6 range.setValues(values); 7}

投稿2023/07/16 00:37

編集2023/07/16 01:48
YellowGreen

総合スコア731

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問