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

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

新規登録して質問してみよう
ただいま回答率
85.35%
Google スプレッドシート

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

Q&A

解決済

1回答

2457閲覧

スプレッドシートにて半角カナ→全角カナに変換したいです。

tagg

総合スコア8

Google スプレッドシート

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

0グッド

0クリップ

投稿2020/06/05 10:11

前提・実現したいこと

スプレッドシートにて、半角カナを全角カナに変換したのですが、EXCELにあるJIS関数が使えないため、
ネット(Github)上にあるコードを参照にしているのですが、エラー表示が出て先に進めない状態です。

発生している問題・エラーメッセージ

TypeError: Cannot read property 'split' of undefined

該当のソースコード

function kana2upper(string) { var arrayedString = string.split(''); var value = ''; var triTable = { }; var biTable = { }; var uniTable = { 'ガ': 'ガ', 'ギ': 'ギ', 'グ': 'グ', 'ゲ': 'ゲ', 'ゴ': 'ゴ', 'ザ': 'ザ', 'ジ': 'ジ', 'ズ': 'ズ', 'ゼ': 'ゼ', 'ゾ': 'ゾ', 'ダ': 'ダ', 'ヂ': 'ヂ', 'ヅ': 'ヅ', 'デ': 'デ', 'ド': 'ド', 'バ': 'バ', 'ビ': 'ビ', 'ブ': 'ブ', 'ベ': 'ベ', 'ボ': 'ボ', 'パ': 'パ', 'ピ': 'ピ', 'プ': 'プ', 'ペ': 'ペ', 'ポ': 'ポ', 'ヴ': 'ヴ', 'ヷ': 'ヷ', 'ヺ': 'ヺ', 'ア': 'ア', 'イ': 'イ', 'ウ': 'ウ', 'エ': 'エ', 'オ': 'オ', 'カ': 'カ', 'キ': 'キ', 'ク': 'ク', 'ケ': 'ケ', 'コ': 'コ', 'サ': 'サ', 'シ': 'シ', 'ス': 'ス', 'セ': 'セ', 'ソ': 'ソ', 'タ': 'タ', 'チ': 'チ', 'ツ': 'ツ', 'テ': 'テ', 'ト': 'ト', 'ナ': 'ナ', 'ニ': 'ニ', 'ヌ': 'ヌ', 'ネ': 'ネ', 'ノ': 'ノ', 'ハ': 'ハ', 'ヒ': 'ヒ', 'フ': 'フ', 'ヘ': 'ヘ', 'ホ': 'ホ', 'マ': 'マ', 'ミ': 'ミ', 'ム': 'ム', 'メ': 'メ', 'モ': 'モ', 'ヤ': 'ヤ', 'ユ': 'ユ', 'ヨ': 'ヨ', 'ラ': 'ラ', 'リ': 'リ', 'ル': 'ル', 'レ': 'レ', 'ロ': 'ロ', 'ワ': 'ワ', 'ヲ': 'ヲ', 'ン': 'ン', 'ァ': 'ァ', 'ィ': 'ィ', 'ゥ': 'ゥ', 'ェ': 'ェ', 'ォ': 'ォ', 'ッ': 'ッ', 'ャ': 'ャ', 'ュ': 'ュ', 'ョ': 'ョ', '。': '。', '、': '、', 'ー': 'ー', '「': '「', '」': '」', '・': '・' }; if(triTable[string] !== undefined){ return triTable[string]; } else if(biTable[string] !== undefined) { return biTable[string]; } var biCheck = new Object(); for (var k in biTable){ var tmp = k.split(''); biCheck[tmp[0]] = true; } var triCheck = new Object(); for (var tk in triTable){ var tmp = tk.split(''); triCheck[tmp[0] + tmp[1]] = true; biCheck[tmp[0]] = true; } var buf = ''; for(var i = 0; i < arrayedString.length ; i++){ var str = arrayedString[i]; buf += str; if(buf.length == 3){ if(triTable[buf] !== undefined){ value += triTable[buf]; } else { tmp = buf.split(''); value += biTable[tmp[0] + tmp[1]]; value += uniTable[tmp[2]] === undefined ? tmp[2] : uniTable[tmp[2]]; } } else if(buf.length == 2) { if(triCheck[buf] !== undefined) { } else if(biTable[buf] !== undefined) { value += biTable[buf]; buf = ''; } else { tmp = buf.split(''); value += uniTable[tmp[0]]; value += uniTable[tmp[1]] === undefined ? tmp[1] : uniTable[tmp[1]]; buf = ''; } } else if(biCheck[buf] !== undefined){ } else { value += uniTable[str] === undefined ? str : uniTable[str]; buf = ''; } } value += buf !== '' ? uniTable[buf] : ''; value = value.replace(/([aiueo])ー/gi,'$1'); return value; }

試したこと

splitの後ろにある()内を色々と別のものに置き換えたのですが状況が変わらず、
公開されているものを参照にしているに過ぎないため、何を変更すればよいのかがわからない状態です。
※初心者のため、書かれているコードについてそもそもの理解ができておりません。。。
解決法、もしくは別のコードにおいて半角カナと全角カナにできるものがあればご教示いただきたく思います。

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

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

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

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

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

guest

回答1

0

ベストアンサー

使い方が間違ってるかと思います。コードを実行してませんか?

これはいわゆる自作関数ってやつなので、例えば A1に 半角カナを含む文字列があって、
それを全角カナに変換したいなら 適当なセルに

=kana2upper(A1)

といった感じで関数として入れてあげると動作すると思います。

投稿2020/06/05 13:55

sawa

総合スコア3002

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

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

tagg

2020/06/08 02:46

ご回答ありがとうございます。 なるほど、利用方法が間違っていたわけですね。 実際にご教示いただいたようにセルに入れて実行してみたところ、半角カナが半角カナのまま出てきてしまい、全角カナに変換されませんでした。 数式自体が違うのか、スクリプトの反映のさせかたが違うのか、わかりかねるのですが、やり方さがしてみます。 ありがとうございます。
sawa

2020/06/08 03:31

あれ、動きませんか? 特にコードいじることなく、そのまま貼り付ければ関数として機能しました。 新しいシートに貼り付けて、再度試してみてはいかがでしょうか?
tagg

2020/06/08 04:06

すみません、再度別シートで実施してみたところ、作動いたしました。 ご回答ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問