No.10ベストアンサー
- 回答日時:
巨大なファイルを作ることはできたズラw
これを応用したら、もしかして読める?
Dim i As Long
Dim h As Long
Dim m As Long
Dim l As Long
Dim sz As Long
sz = &H80000
h = CreateFile("c:\temp\big.txt", GENERIC_WRITE, _
0, 0, OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0)
m = GlobalAlloc(GMEM_FIXED, sz)
For i = 1 To 100
Call WriteFile(h, m, ByVal sz, VarPtr(l), ByVal 0)
Next
Call GlobalFree(m)
Call CloseHandle(h)
ありがとう。
上の例で試したら50MBのファイルができたよ。
ヒントをありがとう。
何とかできそうですよ。
ただ、アドレスを直接していするとオーバフローするので
ちとやり方を変えちゃったけどね。
No.8
- 回答日時:
前回の回答は少し間違っていたけど、
3GB目から128byteは
Dim wk(0 To 127) As Byte
Open "hoge" For Random As #1 Len = 128
Get #1, 3@ * 1024@ * 1024@ * 1024@ / 128@ + 1, wk
Close #1
で出来るはず。
Len節でレコードサイズを128byteで指定しているので
Getの第2引数は128byte単位のレコード番号です。
開始位置が128で割り切れない場合は一工夫が必要です。
この回答への補足
Get #1, 3@ * 1024@ * 1024@ * 1024@ / 128@ + 1, wk
ここでファイル名または番号が違います と出てしまうよ・・
3@ を 1@にするとうまくいくんだけど・・・
オーバーフローでGETじゃ無理なんじゃ?・・・
※Rnadomでなくてバイナリーモードでオープンしたいんですよねー
No.5
- 回答日時:
Dim wk(0 To 127) As Byte
Open "hoge" For Random As #1 Len = 128
Get #1, 2@ * 1024@ * 1024@ * 1024@ / 128@, wk
Close #1
この回答への補足
うーーむ・・・
上の例ってRandomアクセスで2GBアドレスじゃないよね
バイナリファイルで、3GBのアドレス位置から128バイト読みたいんだけど・・・
Get #1, 3@ * 1024@ * 1024@ * 1024@ ,wk
こんな感じ
うまい方法ないかな?
オーバーフローしちゃうし、GETでも無理だね?
No.4
- 回答日時:
恥ずかしながら、SEEK関数の便利さがよくわからなかった。
とりあえず、#3に便乗して、SetFilePointerのサンプル
(googleでひっかかったところで、よさ気なところ)
http://oshiete1.goo.ne.jp/kotaeru.php3?q=570918
この回答への補足
http://oshiete1.goo.ne.jp/kotaeru.php3?q=570918 ??
2ch様! これってここのアドレスなんだけど・・
どういうこと? かな・・
No.3
- 回答日時:
> ACCESSで、2GB以上のファイルを扱いたいのですが、
外部ファイルからデータを取込みたいということかな?
VBでのファイル操作に関して言えば
SEEK 関数の引数に指定できる範囲は
1 ~ 2,147,483,647 (long)
なので仕様として不可能です。
API関数 "SetFilePointer" を使用すれば可能かも?
win32apiですかー
サンプルとなるSRCがあったら教えてください。
よろしくお願いします。
ちなみに外部ファイルでバイナリの4GBのファイルから
2GB以上のアドレスからデータを取得したいのです。
※ファイル分割しない方法でお願いします。
No.2
- 回答日時:
今のソースはどうなっているんだ?
この回答への補足
どうも
今のソースはこうなっているよ
Dim wk(128) As Byte
Seek #1, pos <--ここのposに、2GB以上のアドレスを記述したい。
Get #1, , wk
seekステートメントじゃ無理なのは知っている。
なので、可変長のバイナリファイルの外部ファイルを2GBアドレス以上のファイルポインターを指定してデータを読み込む方法はないのかね?
たとえば、関数じたいを作るとか、APIを使用するとか
そういう例があったら公開してほしい。
2ch様よろしくお願いします!
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
ロボットの住む世界で流行ってる罰ゲームとは?
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
Microsoft VBAで2GBを超えるファイルサイズのバイナリデータを読み込みたい。
Visual Basic(VBA)
-
Excel VBAにて、2GB超の点群データ(CSVファイル,改行コードLF)を高速で解析したい。
Visual Basic(VBA)
-
Long型で表現できないファイルサイズへの対応
Excel(エクセル)
-
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Eclipseで検索ができなくなった
-
0バイトのテキストファイル
-
【Excel VBA】取り込んだファイ...
-
サイトマップにサブドメインを...
-
C++.NET 2003 「空のドキュメ...
-
<input type="file" で初期値...
-
VB6.0のメモリリークについて
-
BASP21のファイルアップロード...
-
C#でtiffファイルのページ数を取得
-
Windowsアプリケーションでカー...
-
VBAで、JPG写真の撮影日時を読...
-
ファイル作成日時と更新日時を...
-
main関数のコマンドライン引数...
-
ディレクトリのサイズの取得
-
リソースファイルを認識してく...
-
【VBA】複数CSVの特定範囲を1つ...
-
ファイル内容を比較する方法
-
INIファイルへの保存について
-
エディットボックスの内容をテ...
-
includeで別サイトを読み込む
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【Excel VBA】取り込んだファイ...
-
0バイトのテキストファイル
-
Eclipseで検索ができなくなった
-
VBAで、JPG写真の撮影日時を読...
-
HTMLテキストリンクでExcelファ...
-
BASP21のファイルアップロード...
-
C++.NET 2003 「空のドキュメ...
-
main関数のコマンドライン引数...
-
VB2008 iniファイルの全セクシ...
-
サイトマップにサブドメインを...
-
【VBA】複数CSVの特定範囲を1つ...
-
Javaのファイルダウンロードに...
-
RPGでメッセージファイル利用
-
vbaの構文の修正相談(xmlファ...
-
2GB以上のファイルを扱う方法
-
VBAでフォルダ内の全てのcsv...
-
msgget()で指定するkey値について
-
ファイルの排他について
-
VB6.0のメモリリークについて
-
VBSで、日本語文字列の抽出が、...
おすすめ情報