新着表示
タイトル
記事No
投稿日
投稿者
: Re: idx_search 続き
: 676
: 2015/02/11(Wed) 19:03:26
: JA2BQX 太田
こんばんは、度々お世話になります。
> idx_next() を使い、日付が変わるまでループします。
Idx_ReadKey() および VBでは Vidx_ReadKey() ですが
この関数では直接インデックスキー文字列が取れるようですが Call と Code しかないようです。
Date もあるとFBかと思いますが。
このスレッドは管理者によってロックされていますので、返信並びに編集は出来ません!
タイトル
記事No
投稿日
投稿者
: Re: idx_search 続き
: 675
: 2015/02/11(Wed) 18:20:31
: JA2BQX 太田
こんばんは、ありがとうございます。
> idx_next() を使い、日付が変わるまでループします。
dbf_read() や THW_read() でhdbを読み込み日付を取得して
変わったかを確認すると言う事でしょうか?
このスレッドは管理者によってロックされていますので、返信並びに編集は出来ません!
タイトル
記事No
投稿日
投稿者
: Re: idx_search 続き
: 674
: 2015/02/11(Wed) 17:38:04
: JG1MOU浜田
idx_next() を使い、日付が変わるまでループします。
このスレッドは管理者によってロックされていますので、返信並びに編集は出来ません!
タイトル
記事No
投稿日
投稿者
: Re: idx_search 続き
: 673
: 2015/02/11(Wed) 11:23:15
: JA2BQX 太田
> 例えば Hamlog.hdb に 日付が "20010203" のデータが
日付を1日づつ加算して行きレコード番号が求められたらそのー1を求める手もありますね。
このスレッドは管理者によってロックされていますので、返信並びに編集は出来ません!
タイトル
記事No
投稿日
投稿者
: idx_search 続き
: 672
: 2015/02/11(Wed) 10:34:33
: JA2BQX 太田
こんにちは。お世話になります。
先日の idx_search の続きですが、
例えば Hamlog.hdb に 日付が "20010203" のデータが
レコード番号 100から104までだったとして下記で最初の 100 は求まります。
キー "20010203" の最後の 104 を求めるにはどうすれば良いでしょうか?
100から順番にhdbを読み込み、 Date を求めて行き、"20010203" ではなくなるレコードまで
順次判定して行くしかありませんか?
MakeIndex(hamlogpath, "DATE", "C:\thw2adi\Date.Ndx")
Dim str As String = "20010203"
途中省略
rec_no_1st = idx_search(THindx, search_date, 0)
下記関数の使い方が分かっていないからかも知れませんが。
idx_top() : hdbの最初のレコード番号 1
idx_bottom() : hdbの最終レコード番号
上記では単純過ぎるので、正しい使い方が他にあるのかも?
idx_next() : キーで検索されたレコード番号の次。
このスレッドは管理者によってロックされていますので、返信並びに編集は出来ません!
タイトル
記事No
投稿日
投稿者
: Re: idx_search
: 671
: 2015/02/09(Mon) 22:07:21
: JA2BQX 太田
こんばんは。浜田さん、ありがとうございます。
午前中から 同じようなことをしているのですが成功していませんでしたが
今、改めてテストしたら取得出来るようです....。
> 分の数値 or &H80 です。
Dim str As String = "1200"
fp0 = Val(str.Substring(0, 2))
fp1 = Val(str.Substring(2, 2))
search_time_ary(0) = CByte(fp0)
下記のどちらでOKです。
search_time_ary(1) = &H80 Or CByte(fp1)
search_time_ary(1) = CByte(128) Or CByte(fp1)
午前中のテストとコードは変わらないのですがテスト環境 (Hamlog.hdb) が間違えていたのかな....??
次の Date+Time のUTCも取れるようになりました。
的確なアドバイスを何時もありがとうございます。
このスレッドは管理者によってロックされていますので、返信並びに編集は出来ません!
タイトル
記事No
投稿日
投稿者
: Re: idx_search
: 670
: 2015/02/09(Mon) 20:28:13
: JG1MOU浜田
> 1200 でサーチすると 12:00 J のレコード番号が求められます。
> 12:00 U のレコード番号を求めるにはどうしたらいいでしょうか?
分の数値 or &H80 です。
分 = 分 or &H80
論理和っていうのでしょうか。
逆に、最上位ビットをカットして分の値を取り出すには、
分の数値 and &H7F です。
分 = 分 and &H7F
論理積っていうのでしょうか。
このスレッドは管理者によってロックされていますので、返信並びに編集は出来ません!
タイトル
記事No
投稿日
投稿者
: Re: idx_search
: 669
: 2015/02/09(Mon) 07:50:01
: JA2BQX 太田
こんにちは。
> バイト型の配列の1要素に、文字列?がコピーできてしまうのですか。
例の暗黙的変換?をしてくれているのかも、Hi。
str = "1200"
fp0 = Val(str.Substring(0, 2))
fp1 = Val(str.Substring(2, 2))
search_time_ary(0) = CByte(fp0)
search_time_ary(1) = CByte(fp1)
...とかが良いでしょうね、これで動きます。
1200 でサーチすると 12:00 J のレコード番号が求められます。
12:00 U のレコード番号を求めるにはどうしたらいいでしょうか?
Hamlog50.txt には 分の最上位ビットが1であればUTC とあります。
1000 0000 は 16進数で 80 なので10進数の128を加算して
12 と 128+0 をバイト配列に入れてテストしていますが間違いのようです。
どのように処理すれば良いのでしょうか?
このスレッドは管理者によってロックされていますので、返信並びに編集は出来ません!
タイトル
記事No
投稿日
投稿者
: Re: idx_search
: 668
: 2015/02/08(Sun) 22:53:51
: JG1MOU浜田
> Dim search_date As String
> Dim search_date_ary(4) As Byte
>
> search_date_ary(0) = "20"
> search_date_ary(1) = "15"
> search_date_ary(2) = "01"
> search_date_ary(3) = "05"
バイト型の配列の1要素に、文字列?がコピーできてしまうのですか。
また、エンコードルーチンを呼び出す必要があるのですね。
いずれにしても、インデックスルーチンを使うと、検索がめちゃくちゃ
高速になります。
ハムログにおける、コールサインのサフィックス・サーチやワイルドカ
ード・サーチでは、HAMLOG.DX0からサーチしてますので20万件以上の
データから任意の100件くらいを探し出すのでも、瞬時に表示して
くれます。
このスレッドは管理者によってロックされていますので、返信並びに編集は出来ません!
タイトル
記事No
投稿日
投稿者
: Re: idx_search
: 667
: 2015/02/08(Sun) 18:16:29
: JA2BQX 太田
浜田さん、何回もありがとうございました。
下記のように修正したら目的のレコード番号が取得出来ました。
Dim search_date As String
Dim search_date_ary(4) As Byte
search_date_ary(0) = "20"
search_date_ary(1) = "15"
search_date_ary(2) = "01"
search_date_ary(3) = "05"
MakeIndex(hamlogpath, "DATE", "C:\thw2adi\Date.Ndx")
Ret = idx_open("C:\thw2adi\Date.Ndx", THindx)
search_date = System.Text.Encoding.GetEncoding(932).GetString(search_date_ary)
rec_no_1st = idx_search(THindx, search_date, 0)
Call idx_close(THindx)
このスレッドは管理者によってロックされていますので、返信並びに編集は出来ません!