
No.4ベストアンサー
- 回答日時:
またまた登場、onlyromです。
>duble型と宣言しているのに、また#付きとは。
>この場合は#なくても同じということに・・・?
そうです、#はなくてもいいです。
先の回答の
Const K As Double = 5000# '#はあっても無くてもいい
と同じことです。
要するに
■値を代入するだけ■なら、#はあってもなくてもいいわけですが、
先の回答の例のように計算に使ってる場合は、
#があるないかが重要になってくるわけです。
また、定数をそのまま使う場合は、
定数に#を付けることで宣言部分を見なくても
左辺の変数の型がDouble型というのが分かるというメリットはあるわけですが。。
ただ、これも変数の付け方を定石どおりやれば
変数の型もその変数名を見れば一目で分かります。
先の回答のように、
整数だったら、integerの頭3桁を取り、intData
倍精度だったら、doubleですから、dblData
とすれば変数名を見ただけで変数の型は分かりますよね。
ちょとだらだらとした回答になりました。(^^;;;
少し時間が開いてしまいました。
なるほどです。。
私が見ているソースはまさに計算で使用されていますので、
また少し考えます。
それにしても質問の本文に書きましたが、
'_____________________________________
if kakudo < 0 then
if kakudo <= 1# then
kai = 180 + kakudo
else
kai = 180
end if
else
kai = 0
end if
'_____________________________________
これの式はメチャメチャですが、if文の条件はそのままなのです。
一つ目のif文だけで2つ目のif文はいらないような気がしてしまいます・・・
#が付く事で何かif文の条件が変わるのかと思っていましたが・・・
難しいですね・・・
No.5
- 回答日時:
またまたまた登場、onlyromです。
当方の回答は、そのコードが正しい云々とは関係なく、
質問のタイトルにある、「条件文にある#の意味」その一点についてです。
コードの正誤は質問者の担当?ということで敢えてそこには言及しませんでした。。。(^^;;;
では質問のコードについて。
仰るように間違ったコードですね。
実際は次のようなことだと推測されます。
一行目の
if kakudo ■< 0■ then
この、<0 は、 >0 のタイプミス(よく言えば)でしょう。
'--------------------------------------------------
If kakudo > 0 then
If kakudo <= 1 then
kai = 180 + kakudo
Else
kai = 180
End If
Else
kai = 0
End if
'----------------------------------------------
kakudoが
■0より大きくて1以下■0<kakudo<=1
・・・・kaiに、kakudo+180を代入
■1より大■1<kakudo
・・・・kaiに、180を代入
■0以下■kakudo<=0
・・・・kaiに、0を代入
尚、IF文でも、#はあってもなくても可です。
それにしても
>#が付く事で何かif文の条件が変わるのかと思っていましたが
ここが質問の要点だとは想像もしませんでした。
道理でどうも論点がずれているような、
しっくりこないような気がしてたのですが、
それが原因だったのですねぃ。(^^;;;
最後の方は私の仕事も絡んでしまいました・・
申し訳ないです。
それにしてもこれだけ親切にご教示いただいたので、
だんだんと解明できそうな気がしてきました。
長々とお付き合い頂きありがとうございました。
またすぐに壁に当たるかもですが・・・
No.3
- 回答日時:
回答2、onlyromです。
回答1さんがお忙しいようなので。。。
>ここで使用している1はdouble型ですよという意味?
そうです。
なぜ、定数に#などつけるかというと
次の例を試してみればはっきり理解できるはずです。
'-------------------------------------
Private Sub Command1_Click()
Dim intData As Integer
Dim dblData As Double
intData = 30000
dblData = intData + 5000
MsgBox dblData
End Sub
'-------------------------------------
上記では定数5000に、#が付いてないので
dblData = intData + 5000
ここで、オーバーフローのエラーになります。
なぜなら、intDataも5000も整数ですから
計算結果35000は整数の上限32767を超えるからです
で、それを避けるために5000に#を付けDoubleにすると
計算結果はDobuleの範囲内ということで上手くいくわけです。
ただ、コード内に定数を直接使うことはあまりないと思われます。
上記のようなことに常に注意しないといけないからです。
で、どうするかというと
'-------------------------------------------
Private Sub Command1_Click()
Dim intData As Integer
Dim dblData As Double
Const K As Double = 5000# '#はあっても無くてもいい
intData = 30000
dblData = intData + K
MsgBox dblData
End Sub
'-------------------------------------------
と定数5000を予めDoubleの変数に入れておき、
計算などのときはその変数を使うのが普通です。
この回答への補足
早速の回答感謝です。
しかも例があって分かりやすいこと!
理解できてきました。
その後ソースを読み進んでいくと、更に謎な部分が出てきました。
'_______________________________________________
Dim Data As Double
Data = 0#
'________________________________________________
duble型と宣言しているのに、また#付きとは。
この場合は#なくても同じということに・・・?
No.2
- 回答日時:
No.1
- 回答日時:
ここで使用されている「#」は、型宣言文字です
サフィックスと称されます
なので、
1# は、 Double型の1です
VB6の型宣言文字には、他にも「!(Single)」「$(String)」等があります
ぐぐってみるのもいいでしょう
コードのほうは・・・
この回答への補足
早速の回答ありがとうございます。
すみませんもう少し御教示ください。
1というdouble型の変数を宣言したということでしょうか?
それともここで使用している1はdouble型ですよという意味・・・ 同じこと?
混乱してきました。。。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) ファイル全てを .xlsm に変更したところ、プログラムが途中で落ちてしまっています 17 2022/12/07 12:03
- Visual Basic(VBA) VBAの繰り返し処理について教えてください。 3 2022/08/02 13:21
- Visual Basic(VBA) excel VBA if文について 3 2022/03/27 17:42
- Visual Basic(VBA) 実行時エラー´5854´ 文字列型パラメーターが長すぎます。 3 2023/06/08 21:17
- Excel(エクセル) R列の1111/11/11以外、且つQ列の×の条件で該当行のAからAE列までオレンジに塗りつぶす 2 2022/07/02 10:18
- Visual Basic(VBA) VBAが止まります。 3 2022/08/31 14:09
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Visual Basic(VBA) [Excel VBA] このコードでは行の挿入や行の消去をすると13のエラーが出てしまう。 3 2022/12/09 00:29
- PostgreSQL DBFluteについて質問です。 環境:PostgreSQL java8 前提:webアプリケーショ 1 2022/07/07 00:49
- Visual Basic(VBA) VBAでoutlook365が起動しません。 4 2022/08/25 13:31
このQ&Aを見た人はこんなQ&Aも見ています
-
ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
高校生はアルバイトするべきだろうか?
-
「これはヤバかったな」という遅刻エピソード
寝坊だったり、不測の事態だったり、いずれにしても遅刻の思い出はいつ思い出しても冷や汗をかいてしまいますよね。
-
限定しりとり
文字数6文字以上の単語でしりとりしましょう
-
これ何て呼びますか Part2
あなたのお住いの地域で、これ、何て呼びますか?
-
かっこよく答えてください!!
あなたは今にも別れそうなカップルの彼女の恋愛相談に乗っています。
-
Form_Load と Form_Activate のタイミング
Visual Basic(VBA)
-
VBの質問#if 0 then ってどう言う意味?
Excel(エクセル)
-
定数配列の書き方
Visual Basic(VBA)
-
-
4
VB6のAttribute VB_Nameの意味について
Visual Basic(VBA)
-
5
VB6のプロジェクトロードエラーについて
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
今、見られている記事はコレ!
-
釣りと密漁の違いは?知らなかったでは済まされない?事前にできることは?
知らなかったでは済まされないのが法律の世界であるが、全てを知ってから何かをするには少々手間がかかるし、最悪始めることすらできずに終わってしまうこともあり得る。教えてgooでも「釣りと密漁の境目はどこです...
-
カスハラとクレームの違いは?カスハラの法的責任は?企業がとるべき対応は?
東京都が、客からの迷惑行為などを称した「カスタマーハラスメント」、いわゆる「カスハラ」の防止を目的とした条例を、全国で初めて成立させた。条例に罰則はなく、2025年4月1日から施行される。 この動きは自治体...
-
なぜ批判コメントをするの?その心理と向き合い方をカウンセラーにきいた!
今や生活に必要不可欠となったインターネット。手軽に情報を得られるだけでなく、ネットを介したコミュニケーションも一般的となった。それと同時に顕在化しているのが、他者に対する辛らつな意見だ。ネットニュース...
-
大麻の使用罪がなかった理由や法改正での変更点、他国との違いを弁護士が解説
ドイツで2024年4月に大麻が合法化され、その2ヶ月後にサッカーEURO2024が行われた。その際、ドイツ警察は大会運営における治安維持の一つの方針として「アルコールを飲んでいるグループと、大麻を吸っているグループ...
-
ピンとくる人とこない人の違いは?直感を鍛える方法を心理コンサルタントに聞いた!
根拠はないがなんとなくそう感じる……。そんな「直感がした」という経験がある人は少なくないだろう。ただ直感は目には見えず、具体的な説明が難しいこともあるため、その正体は理解しにくい。「教えて!goo」にも「...
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・「それ、メッセージ花火でわざわざ伝えること?」
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・【お題】甲子園での思い出の残し方
- ・【お題】動物のキャッチフレーズ
- ・人生で一番思い出に残ってる靴
- ・これ何て呼びますか Part2
- ・スタッフと宿泊客が全員斜め上を行くホテルのレビュー
- ・あなたが好きな本屋さんを教えてください
- ・かっこよく答えてください!!
- ・一回も披露したことのない豆知識
- ・ショボ短歌会
- ・いちばん失敗した人決定戦
- ・性格悪い人が優勝
- ・最速怪談選手権
- ・限定しりとり
- ・性格いい人が優勝
- ・これ何て呼びますか
- ・チョコミントアイス
- ・単二電池
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・ゴリラ向け動画サイト「ウホウホ動画」にありがちなこと
- ・泣きながら食べたご飯の思い出
- ・一番好きなみそ汁の具材は?
- ・人生で一番お金がなかったとき
- ・カラオケの鉄板ソング
- ・自分用のお土産
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBAでダブルコーテーション入り...
-
C言語 列挙型(enum型)変数について
-
エラーの意味は? Lvalue req...
-
EXCEL/VBA 変数の値をクリップ...
-
processing エラーで、 "cannot...
-
Variant型で宣言してるのにEmpt...
-
DataColumn型の使用方法
-
C言語 exitの使い方
-
excelの、ある数式内の{}の意...
-
Excel-vba 文字列と変数を...
-
VBAのWorksheetFunctionの引数...
-
○桁にある数値を取得する VB.N...
-
VB.NET 2つの配列を連動して並...
-
フォームを開くときに、コンボ...
-
エクセルVBAでのチェックボック...
-
フリーランタイマーの時間差分...
-
VisualStudio2022でC言語プログ...
-
エクセル、この関数の意味は?
-
配列の値を置換するにはどうす...
-
VBA コンボボックスの値をスピ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBAでダブルコーテーション入り...
-
EXCEL/VBA 変数の値をクリップ...
-
エラーの意味は? Lvalue req...
-
jsp~jspにhiddenを使って変数...
-
[VBS]変数を定数に変換する方法...
-
Variant型で宣言してるのにEmpt...
-
テキストボックスの値を変数に...
-
プログラミングで変数と関数の...
-
JavaScriptをURLから直接実行し...
-
processing エラーで、 "cannot...
-
整数xxxが大き過ぎますというエ...
-
C言語 アロー演算子について質...
-
C言語 列挙型(enum型)変数について
-
コマンドプロンプト バッチ|結...
-
DataTableの値を変数に代入したい
-
i++と++i ってどう違うのですか?
-
stdpicture型の変数に、、
-
【VBA】複合代入演算子
-
Accessコンボボックスにレコー...
-
PL/Iについて、教えてください。
おすすめ情報