![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?5a7ff87)
ふたつの温度計があって、室温が23度外気温が18度の場合、
シリアル通信によって2318としておくられてきます。
そしてこれがTextBox2に2318と表示されます。
Delegate Sub DataDelegate(ByVal sdata As String)
Private Sub PrintData(ByVal sdata As String)
TextBox2.Text = sdata
End Sub
ここまではなんとかうまくいきました。ここからが質問なんですが、
このsdataをTextBox3とTextBox4に23℃、18℃と分けて表示したいのですが
うまくいきません。substringを使って、
sdata = sdata.Substring(0, 2)
TextBox3.Text = sdata
などとやってみましたが
「インデックスおよび長さは文字列内の場所を参照しなければなりません。」
とエラーとなってうまくいきません。どう書いたらいいのかおしえてください。
尚、シリアル通信は改行コードを頭につけて、\r\n2318 と連続的に送られてくる
んですがこれが問題なんでしょうか。
No.2ベストアンサー
- 回答日時:
>と二行あけて4プラスデータが縦に連続的に表示されます。
2行空けて が何なのか気になりますが。
最初の表示の分は何のかも。
sdata には、4文字しか入っていないようなので。
Private Sub PrintData(ByVal sdata As String)
TextBox2.Text = sdata
TextBox3.text =sdata.Substring(0, 2)
TextBox4.text =sdata.Substring(2, 2)
End Sub
で取得できるはずですが。
又は、
Private Sub PrintData(ByVal sdata As String)
TextBox2.Text = sdata
End Sub
で、TextBox2.Text には、2318 と入っているのなら
Private Sub PrintData(ByVal sdata As String)
TextBox2.Text = sdata
TextBox3.text =TextBox2.text.Substring(0, 2)
TextBox4.text =TextBox2.text.Substring(2, 2)
End Sub
でも同じように取得できるはずです。
この回答への補足
色々ためしてみましたが残念ながらうまくいきませんでした。
「インデックスおよび長さは文字列内の場所を参照しなければなりません。」
とのエラーメッセージがでます。
試しに改行コードを抜いて数字だけを送ると、エラーにはなりませんが文字が全く
表示されなくなります。なんかむずかしいです。
No.1
- 回答日時:
>尚、シリアル通信は改行コードを頭につけて、\r\n2318 と連続的に送られてくる
>んですがこれが問題なんでしょうか。
だったら、sdata に何がどのように入っているか調べてみたら。
Private Sub PrintData(ByVal sdata As String)
Debug.Print(sdata.Length.ToString())
If sdata.Length > 3 Then
For i As Integer = 0 To sdata.Length - 1
Debug.Print(sdata.Substring(i, 1))
Next
End If
End Sub
これで、イミディエイトウィンドウにはどのように表示されましたか?
この回答への補足
回答ありがとうございます。
早速ためしてみたところ
4
2
3
1
8
4
2
3
1
8
と二行あけて4プラスデータが縦に連続的に表示されます。
尚私はVBは全くの初心者でシリアル通信はwebサイトを検索して
シリアル通信プログラムを探し、かたっぱしから試してみたところ、たまたま
うまく動いたもので、プログラムの意味はさっぱり理解していません。
これをどう解釈したらいいんでしょうか。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) エクセルのVBAについて とあるサイトのコードを参考に、CSVの文字化けを直すVBAを作成しているの 7 2022/11/04 14:15
- Visual Basic(VBA) 以下のVBAで該当文字列の前後に付与したい。 例 前に付与 abc ユーザーID 12345 後に付 3 2022/04/19 21:50
- Excel(エクセル) Excelにて、フォルダ内のTextファイルをマクロで統合すると文字化けしてしまう時の解消コード 4 2023/01/01 07:32
- Visual Basic(VBA) ユーザーフォームの書き出しで追加のご相談 ユーザーフォームの値をシートに書き出す際、コードが表示され 2 2022/08/05 10:58
- Visual Basic(VBA) 九九の答えの計算 3 2022/12/20 22:13
- Visual Basic(VBA) VBA 重複チェック後に値をワークシートに転記する方法を教えてください。 1 2023/03/19 12:43
- Excel(エクセル) マクロでテキストファイルを読み込んだ際の最終セルにデータと改行が含まれる問題の改善方法 2 2022/03/25 16:50
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Excel(エクセル) このコードに追記事項の仕方を教えて下さい。 以下のコード内容に出てくる。セルH3が空白の場合、エラー 4 2023/08/03 00:22
- Visual Basic(VBA) Excel VBA キーワードから列を取得して、さらに空欄行を非表示にする 3 2022/10/21 22:49
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ExcelのVBAで文章にある複数の...
-
文字をアクティブにする方法
-
「Thanks 4 sending me」←誤文?
-
XMLファイルのattribute値がう...
-
テキストボックスかラベル上の...
-
あいまい検索方法について
-
ボールの動きがスムーズに動い...
-
VBA public変数はどのようなこ...
-
他のフォームから別のフォーム...
-
VB
-
エクセルVBAでテキストボッ...
-
チェックボックスを操作できな...
-
C#のループでtextboxに値を入れ...
-
VB.NETでのイベントの途中終了
-
テキストボックスに入る文字を...
-
テキストボックスに大文字を
-
visual basic初心者です。 visu...
-
プロシージャまたは関数の引数...
-
Picture box の サイズを変更
-
256色で任意の色を作成する時、...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
sublimit textっていうエディタ...
-
テキストボックスかラベル上の...
-
ExcelのVBAで文章にある複数の...
-
WORd VBA 文章を単語に分解する
-
Googleシート「A1」でなくて「A...
-
Pythonのre.split()の正規表現...
-
XMLファイルのattribute値がう...
-
【VBS】クリップボード操作につ...
-
[VB6] SQLの作成について
-
Pythonでのstrip()とsplit()の...
-
vba 日本語以外を抽出について
-
助けてください!
-
perlによるxmlファイルの取得
-
ReadParseで同名のinput名は配...
-
表の文字の均等割りについて
-
DTPicker テキストクリアの方法
-
VB6.0 sp5]テキストボックスと...
-
文字列を配列に…。
-
文字列を日付型情報として計算...
-
Rubyにおける正規表現(一致し...
おすすめ情報