質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.51%

  • VBA

    1806questions

    VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

  • Access

    432questions

    Accessはマイクロソフトによるリレーショナルデータベース管理システムです。オブジェクト指向のアプリケーション作成に対応しており、テーブルや編集をはじめ、クエリ生成、入力フォーム作成、レポート作成など一通りの機能を備えています。

  • ダウンロード

    33questions

    リモートシステムからローカルシステムへとデータを受信する事、もしくはそのようなデータ転送を行う事をダウンロードと呼びます。

  • ドラッグ&ドロップ

    7questions

    コンピューターのGUIにおいて、バーチャルなものを「つかむ」ことによって選択し、別の場所や他のバーチャルなものの上に動かす行為、またはその行為に対応していることを指す。

ACCESS VBA ネット上の画像をフォームにドラッグアンドドロップで保存

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 2,347

otojiro

score 17

ACCESS で通販用の商品管理をしております。

現在は商品テーブルには商品名やサイズ等、テキストベースの情報しか持っておりません。
今回画像(jpg等)もデータとして持たせようと考えております。

画像の保存方法は、ACCESSのファイルと同じディレクトリにフォルダ「ItemImg」を作りその中に各商品ごとに、フォルダ名「商品ID(0001など)」を作って画像を保存する予定です。

現在は、商品テーブルにフィールド「画像パス」を作り、画像までのフルパスを保存し、フォーム上にはイメージコントロールを配置し、コントロールソースに「画像パス」を指定し表示まではできております。

商品画像は主に、問屋のWEBサイトの画像を使用するため、問屋WEBサイトから画像を右クリックで商品個別のフォルダに保存し、エクスプローラのプロパティーから画像のフルパスを確認、コピーしてデータに登録してようやくフォームに表示という結構めんどくさい状況になっております。

そこでACCESS VBAで下記の処理を実現するためのアドバイスがいただければと思います。

1: WEB上の画像をACCESS フォームにドラッグアンドドロップ(画像をデスクトップにドラッグしてコピーできる画像に限られるのかな?)

2:ドラッグアンドドロップされた画像を指定のフォルダにダウンロード(パスではなくて画像ファイルのコピー)
商品フォームでは新規商品(新規レコード)がつくられると、ACCESSファイルと同じディレクトリに ItemImg>0001(商品ID)のように自動でフォルダが作られるVBAを作成ずみ。

3:商品ID名のついた各フォルダにダウンロード保存した画像ファイルのフルパスを取得して商品テーブルの画像パスに入力

4:フォーム上のイメージコントロールで画像ファイルのフルパスをもとに表示

上記ような流れで実現できないかな?と考えているのですが、特に「1:、2:」のステップがどうやったら可能なのか見当が付きません。

ネット上でACCESS 画像ドラッグアンドドロップなどで検索して、すでにローカル上にある画像ファイルをプログレスバーコントロールにドラッグしてデータに登録などの記事は見つかったのですが、検索の方法が悪いのか、今回やりたい処理に関係する記事が見つけることができませんでした。

どのようなプロセスで実現可能かアドバイスや、関連記事があれば教えていただければと思います。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

自分がやるとしたら、ですが

  1. Web上の画像を指定のフォルダ(商品ID)にダウンロード
  2. フォーム表示時に商品IDから画像ファイルのパスを作成しイメージコントロールにセット

でどうかな?と思いますが・・・
この方法だと質問者さんの要望にあるフォームにドラッグアンドドロップという方法ではありませんし
DBに画像パスが残らないのと、ダウンロード時の操作ミスに関しての不安がありますので
ちょっと乱暴ですかね?

追記

不親切のような気がしたので実験がてら調べてみましたが、質問者さんが検索で見つけられた

ローカル上にある画像ファイルをプログレスバーコントロールにドラッグしてデータに登録などの記事

にあるような方法でフォームを作成し(ProgressBar_OLEDragDropにData.Filesでパスを取得)
そのフォームを使用して、ローカルにあるファイルではなくブラウザから直接ドラッグアンドドロップすると、
ブラウザキャッシュの画像のパスが取れました。
そのままブラウザキャッシュにある画像のパスから目的の(商品IDの)フォルダへファイルコピーし
(FileCopy source, target を使用)、画像フォルダのパスはコピー先なのでそのままDBに登録できます。

ただ、実験的にやってみただけなので、例えばブラウザキャッシュにあるファイルの形式がビットマップになっちゃっていたり、
そもそもブラウザによってキャッシュがちゃんと保存されるのかとか、
いろいろクリアしなければならない問題はあると思いますが、いかがでしょうか。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/02/02 08:23

    ご回答ありがとうございます。
    キャッシュのがぞうパスが取れましたか?
    以前試したときは何も表示されなかったのでもう一度試してみます。
    >(FileCopy source, target を使用)
    とても有益な情報ありがとうございました。

    サイドプログレスバーの方法を検証してみます。

    キャンセル

  • 2017/02/02 10:45

    kjml様
    先ほどプログレスバーへドラッグしてパス名取得の再検証をしてみました、
    ローカルに保存済のファイルのパスは取得できましたが、やはりWEB上の画像をブラウザからドラッグいてみたところ、パス(キャッシュのパスを含め)は表示されませんでした。
    よろしければキャッシュパスが取得できた手順環境をもう少し詳しく教えていただけませんでしょうか?

    こちらのテスト環境は、ACCESS 2013、プログレスバーコントロール(Microdoft ProgressBar Control,version6.0)、WEBブラウザ CHROME

    宜しくお願いいたします。

    キャンセル

  • 2017/02/02 16:38

    あああ、すみません。
    簡単に実験しただけだったのでブラウザの種類はFirefoxしか試してませんでした。
    申し訳ないです。
    ブラウザをいくつか試してみたところ、キャッシュのパスが取れるのはFirefoxのみで
    EdgeやIEではパスが取れませんでした。
    ○Firefox (パス)
    ×Edge(空白)
    ×InternetExplorer(空白)
    Chromeでもダメのようですね。
    それ以外の環境としては、Windows10、Access2010、プログレスバーコントロール(Microdoft ProgressBar Control, version 6.0)です。
    どうにかならないかもう少し考えてみます。

    キャンセル

  • 2017/02/02 19:41

    ご回答ありがとうございます。
    Firefoxでしたか、メインでChrome使ってますが、FireFoxも嫌いではないので試してみます。
    IEも試してみましたが、IEではプログレスバーに持ってきた辞典で「×」マークが出てきましたのでIEはダメそうでした。

    >どうにかならないかもう少し考えてみます。

    ありがとうございます。
    他の方法も考えてもう少し考えてみます。

    キャンセル

  • 2017/02/03 07:55 編集

    ざっと調べてみましたが、APIを使ってドラッグアンドドロップを自前で処理という方法でいけるかもしれません。
    ただ、ブラウザからのドラッグアンドドロップに際してキャッシュなり画像のURLなりの情報が出てきていない事を考えると、ドラッグアンドドロップから画像のパスではなく画像のデータそのものを取得してクリップボード経由などで保存の処理も自前でという事になりそうです。
    ただ、私のAPIの経験が乏しいため具体的にどうすればよいかはまだ検証していませんので引き続き。

    そうなってくると、やはりブラウザ上で指定のフォルダへ画像の保存→Accessで保存されている(はずの)パスを扱う、という手順の方が簡単で実現に近いように思います。

    キャンセル

  • 2017/02/03 08:03

    kjml様
    いろいろアドバイスありがとうございます。

    >そうなってくると、やはりブラウザ上で指定のフォルダへ画像の保存→Accessで保存されている(はずの)パスを扱う、という手順の方が簡単で実現に近いように思います。

    そうですね、多少の手間ですが、少しでも前に進むためにその方法で進めてみます。
    ブラウザからダウンロードする際に事前に画像ファイル名もそのフォルダで1つ目の画像は「1.jpg」等ルールを作って保存する必要がありそうですね。
    APIについても私もほぼ知識ゼロですので、これを機に少し勉強してみます。
    ありがとうございました。

    キャンセル

  • 2017/02/03 08:48

    WebBrowserコントロール(Microsoft Web Browser)はどうだろうかと試してみましたが
    ・Firefoxは同じようにキャッシュのパスが取得
    ・EdgeはURLのドメインまでが(中途半端)
    ・IEは反応すらしない
    と全く使えませんでした。(使えないのは私かもしれませんが)
    参考までに。

    キャンセル

  • 2017/02/03 19:18

    いろいろご検証ありがとうございます。合わせて参考にさせていただきます。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.51%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • VBA

    1806questions

    VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

  • Access

    432questions

    Accessはマイクロソフトによるリレーショナルデータベース管理システムです。オブジェクト指向のアプリケーション作成に対応しており、テーブルや編集をはじめ、クエリ生成、入力フォーム作成、レポート作成など一通りの機能を備えています。

  • ダウンロード

    33questions

    リモートシステムからローカルシステムへとデータを受信する事、もしくはそのようなデータ転送を行う事をダウンロードと呼びます。

  • ドラッグ&ドロップ

    7questions

    コンピューターのGUIにおいて、バーチャルなものを「つかむ」ことによって選択し、別の場所や他のバーチャルなものの上に動かす行為、またはその行為に対応していることを指す。