下記に示す(例:)のように「text1」を「変換規則」に従って「text2」のように変換したいのですが、初心者なもので「VBScript」言語でどの様に書いたら良いのか分かりません。
何方か変換のプログラムを教えて下さい、よろしくお願いいたします。
(例:)
・text1="35 5 43 9 7 43 47 4"
↓このように変換
・text2=" j 5 r 9 7 r v 4"
※分かりやすくするため「空白」を挿入しています。(本来は「空白」の無い文字列)
「変換規則」
ccc(0) = "A"
ccc(1) = "B"
ccc(2) = "C"
・
・
(途中省略):英字大文字と小文字の並びです。
・
・
ccc(49) = "x"
ccc(50) = "y"
ccc(51) = "z"
A 回答 (6件)
- 最新から表示
- 回答順に表示
No.6
- 回答日時:
補足拝見しました。
変換規則を以下のように定義します。
与えられた数字を2桁単位で判定し、その数字が00~51の範囲の場合、
A~zの文字に置換する。
(例 00ならA、01ならB、25ならZ、26ならa、51ならz のように置換)
上記以外の場合は、最初の1文字をそのまま出力し、次の1文字とその次の1文字を2桁の数字として、同様の判定を繰り返し行う。
以下のスクリプトを実行してください。
dim ccc(51)
dim text1,text2
dim pv,v,num
dim i
for i = 0 to 25
ccc(i) = Chr(ASC("A")+i)
next
for i = 0 to 25
ccc(26+i) = Chr(ASC("a")+i)
next
text1 = "355439743 47 4"
pv = ""
text2 = ""
for i = 1 to len(text1)
v = mid(text1,i,1)
if isnumeric(v) = False then
text2 = text2 & pv & v
pv = ""
else
if pv = "" then
pv = v
else
num = clng(pv) * 10 + clng(v)
if num >= 0 and num <= 51 then
text2 = text2 & ccc(num)
pv = ""
else
text2 = text2 & pv
pv = v
end if
end if
end if
next
text2 = text2 & pv
msgbox(text2)
No.5
- 回答日時:
No3です。
変換後の文字が大文字のA~Zの何れかになるようなケースはないのでしょうか。
の返信が
「私も良く分かりませんが、多分あると思います??」
となっております。
ということは、あなたもよくわかってないということなので、
変換規則が不明なままでは、変換用のスクリプトが書けるわけがありません。
たぶん、何かの課題かと思いますので、課題の作成者に、あなたから、
変換規則について問い合わせていただくことは可能でしょうか。
変換規則が明確になれば、変換用のスクリプトが書けると思います。
はい聞いてみました。
次のようなヒントを貰いました。
「ヒント」
左から「2桁」で見て「変換規則」に有れば変換し、無ければ「1桁」の数値とする。
無かった場合は「1桁」戻る。
次にまた「2桁」で見て・・・・・・
これを繰り返す。
No.4
- 回答日時:
変換する Replace 関数を使いましょう
一般的)
https://learn.microsoft.com/ja-jp/previous-versi …
高度)
https://learn.microsoft.com/ja-jp/previous-versi …
ご質問が曖昧なので断言はできませんが、
"26" の文字列を ccc(26) の内容に変換する様な処理を、
26 回ほど繰り返せば目的達成できると思います。
余談ではありますが
大文字を扱うのか、数字の区切りをどう判断するか等々、変換規則が曖昧なままでは正しいプログラムはできません。事前に課題を整理してプログラムできる状態にまで纏めることをお勧めします。
昨今の学校教育が進めているプログラミング教育でも、重視しているのは論理的思考力でありプログラムを書くことではありません。
No.2
- 回答日時:
元データの記述方法に問題がありますね。
たとえば以下のケース。
"35 5 43 4 3 43 47 4"
これは" j 5 r 4 3 r v 4"になるべきでしょうが、実際はスペースがないから
"355434343474"からの変換。これって
"35 5 43 43 43 47 4"という解釈で
" j 5 r r r v 4"という変換もできるからそもそもの表記規則に不備がありますね。スペースで各文字の元情報が分離されていれば変換は可能ですが、この表記では元の文字列をパースして要素に分離することができないから処理も不可能です。
No.1
- 回答日時:
エッジ開いてチャット開けば、チャット先輩に質問できるから
それ利用するといいかもよ、自分が聞いたらこう答えたよ?
---------------------------------------------------------------
VBScriptでの変換プログラムは以下のようになります。
Dim text1, text2, ccc(51), i
text1 = "35 5 43 9 7 43 47 4"
text2 = ""
For i = 0 To 25
ccc(i) = Chr(65 + i)
Next
For i = 26 To 51
ccc(i) = Chr(71 + i)
Next
For Each num In Split(text1, " ")
If IsNumeric(num) Then
text2 = text2 & ccc(CInt(num))
Else
text2 = text2 & num
End If
Next
MsgBox text2
コピー
このプログラムでは、text1をスペースで区切り、
各要素が数値かどうかを判断しています。
数値であれば、ccc配列の対応する要素をtext2に追加し、
数値でなければそのままtext2に追加しています。
このプログラムを実行すると、text1がtext2に変換され、
メッセージボックスに表示されます。変換規則は、
配列cccに格納されています。この配列は、
大文字アルファベットと小文字アルファベットが順番に並んでいます。
このプログラムを参考にして、ご自身のニーズに合わせて
カスタマイズしてみてください。
---------------------------------------------------
以上、参考になれば幸いです。
回答ありがとうございます。
このプログラムを実行してみましたが、全てが英字に変換されます。
(数値になる所が、英字大文字に変換されている。)
それから、「text1」も「空白」の無い文字列なのでこのままだとエラーが出ます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) Excel VBAでAA(BBB) → BBB.AA に置換したい 2 2022/10/30 13:59
- Visual Basic(VBA) Excel VBA 教えてください。 VBA初心者です。 詳しい方がいましたら教えてください。 下記 3 2023/04/25 11:22
- Windows 10 バッチファイルの記述法とルールについてアドバイスをお願いいたします。 1 2022/04/13 10:50
- マウス・キーボード ctrl+c を ccc連打 に置き換えることはできますか? 1 2022/10/12 10:37
- その他(プログラミング・Web制作) FORTRAN77の配列(除算) 2 2023/02/01 14:34
- フリーソフト フォルダ、ファイル名の一括変換について 3 2023/03/16 09:23
- その他(Microsoft Office) Microsoft IME 一発で変換できない言葉がある 3 2022/07/19 19:29
- JavaScript JavaScript|特定URLだった時、特定の要素を変更するコードの書き方を教えてほしいです 2 2023/08/25 21:43
- Visual Basic(VBA) 特定の文字を簡単な操作で半角スペースに変換するか削除したい 2 2022/11/01 10:35
- Excel(エクセル) ¥マークを含むパスの処理について(マクロ、または関数) 2 2022/12/25 02:11
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・ハマっている「お菓子」を教えて!
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
拡張子を変換するコマンド
-
isoをimgに変換したいのですが...
-
StrConvの使い方について教えて...
-
C++からCへのソース変換について
-
tex 郵便記号のだしかた
-
bitmapクラスをiconクラスに変...
-
c++でmatからvectorへの変換の...
-
色の変換
-
エクセルVBAの自動変換機能?
-
三角形を逆三角形にしたいです...
-
魚眼レンズの画像処理
-
「変換不可」の正しい英語表現
-
MATLABのMATファイル をC言語...
-
MATLAB/simulinkでのD/A変換の仕方
-
画像ファイルから.icoフォーマ...
-
旧暦の取得
-
VB.NETをJavaに変換するツール...
-
逆コンパイルと逆アセンブルの...
-
Excel2013のVBでFT245を制御したい
-
VB.NETとVB6.0でAPIを使う場...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
緯度、経度の 10進法と 60進法...
-
家電製品の電力周波数を変える機械
-
Mac 乗数の入力方法
-
3のつく数字と3の倍数のみを表...
-
エクセルVBAの自動変換機能?
-
C++からCへのソース変換について
-
C/C++→JAVAに変換するツール
-
分を時間に変換するプログラム
-
なぜ通信には16進数文字列が使...
-
エクセルのvbaで検索ボタンを作る
-
c++でmatからvectorへの変換の...
-
php
-
10進数をBCDに変換する方法
-
VB6からVB2010への変換について
-
C#でのpngからbmpへの変換について
-
VB 6 を VS 2012に変換するには?
-
bitmapクラスをiconクラスに変...
-
UTF8→ShiftJISに変換したいです!
-
VB6で10進数を32進数に変換する...
-
逆コンパイルと逆アセンブルの...
おすすめ情報