
Accessフォーム上でExcelインポート処理を作成しました。
自分ではなくユーザーが使うためのツールとして提供する予定です。
このインポート時にユーザーがExcelファイルを編集(列の追加)をしてしまうケースがあり、そのファイルをインポートしようとすると「実行時エラー2391」で止まってしまいます。
この挙動を回避するため「実行時エラー2391」の発生前にこれを防ぐ処理を考えています。
エラーの検知は経験がなく苦慮しています。
ご存知の方いらっしゃいましたらお知恵をお貸しください。
よろしくお願いいたします
No.4ベストアンサー
- 回答日時:
その認識で間違っていません。
処理の流れとしては
①エクセルブックを開く
②インポートするシートの存在チェックと取得(オブジェクトに格納)
③ヘッダーの確認
④明細行の開始位置の確認
⑤ブックを閉じる
⑥Accessにインポートする
といったところでしょうか。
ありがとうございます!
やはりその手順ですよね。
それは提案してみたのですが、
この作業の効率化が目的なので手順が増えるとの指摘で却下されてしまいました。
やはり「Excelファイルの編集はエラーの原因になるため絶対禁止!」
という運用でカバーするのがベストなのかもしれませんね。
いろいろとご丁寧な回答をいただきありがとうございました!!
No.6
- 回答日時:
こんにちは
よこからですが・・・
全体像が分かっていないので的外れかもしれませんが、
>ユーザーがExcelファイルを編集(列の追加)をしてしまうケースがあり
列の編集等が正規の使い方ではないということのようですので、まず、
・そのことの説明をきちんと行う
二つ目には、
・エクセルファイルの「保護」機能で、必要以外の操作を禁止しておく
の両方を行っておくことで、問題の発生をあらかじめ回避できるのではないかと推測します。
No.5
- 回答日時:
No.2です。
> やはり運用で解決しなくてはならない領域なんですね。
「運用」という言い方はちょっと違います。
「運用」というとシステムを提供する側からすると「逃げ」のニュアンスがあります。「本来はこうするのがよいのだが、それは難しいので人間にこう対応してもらおう」といった。。。
そうではなく作業者が我慢や面倒を感じることなくかつ、正しいデータがシステム中のソフトウェアに入力されうような「操作手順」を開発するというスタンスです。
No.2
- 回答日時:
> このインポート時にユーザーがExcelファイルを編集(列の追加)をしてしまうケースがあり、
まずはお客様がなぜそれを行うのか、どういう必要性があるのかを確認することが必要でしょう。
興味本位でいじっているのなら「こういう手順で行わないとこういうエラーにります」と説明し、操作説明書にも明記する必要があります。
全体像が全く見えないのでピンボケコメントかもしれませんが、「作業者はExcelを使っていて、そこで出来上がったExcelファイルの内容をAccessい食わせる」ということなのであれば、作業者がExcelで開いているExcelファイルのシート上には「データ保存」とか「データ出力」とか「終了」とかいったボタンが有って、Excelでの作業を終えたらそのボタンを押すという操作手順にする。
でそのボタンが押されたらExcelマクロで入力データを確認しOKならCSVファイル(TAB区切りではなくカンマ区切り)に書きだす。
このCSVファイルをAccessに食わせる。
CSVファイルではなく該当Excelファイルに特定の名前のシートを追加し、入力シートの所定の範囲を参照してそこにAccessに食わせるデータを作るという方法もありますね。
ということでAccessに食わせる直前(?)にエラーが起きないようにするのではなく、「作業者が勝手に触る可能性のあるデータをAccessに食わせない。必ず正しいデータを食わせる」と考えるのが人間系を含むシステムの機能をまとめる際の正しい思考だと思います。
参考まで。
とても丁寧なコメントをありがとうございます
状況はおっしゃる通りです。
「作業者が勝手に触る可能性のあるデータをAccessに食わせない。必ず正しいデータを食わせる」
これもご指摘の通りで間違いないことだと認識しています。
やはり運用で解決しなくてはならない領域なんですね。
勉強になります。
ありがとうございました!
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
エクセルからアクセスにインポートすると、エラーが出てしまいます。原因を教えていただけませんか。
Access(アクセス)
-
Access VBAでCSVファイルをインポートする方法
Access(アクセス)
-
SQL文で パラメータが少なすぎます エラー
Access(アクセス)
-
-
4
アクセスのエラー「クエリには出力フィールドが1つ以上必要です。」
その他(Microsoft Office)
-
5
accessでクエリをExcelにエクスポートする時にファイル名に日付を追加したい
Access(アクセス)
-
6
エクセルからアクセスにインポートする際のエラーについて
Access(アクセス)
-
7
ACCESSで空白のデーターをクエリで判定/識別する方法を教えてくださ
Access(アクセス)
-
8
AccessからExcelにエクスポートする時に常に上書きしたい
Excel(エクセル)
-
9
標準モジュールだとエラーになる理由を教えてください
Access(アクセス)
-
10
アクセスvbaでエクセルブックを保存
その他(Microsoft Office)
-
11
Access VBAで行ラベルが定義されていないというエラーが出ます
Access(アクセス)
-
12
TransferSpreadsheetのエラー処理
Visual Basic(VBA)
-
13
ACCESS VBAでのインポート
Access(アクセス)
-
14
ACCESS VBAでインポート定義の場所
Access(アクセス)
-
15
access マクロでのフィルタの解除の方法
Access(アクセス)
-
16
アクセスのクエリでSplit関数は使えないのですか
Access(アクセス)
-
17
ラベルとテキストボックスのグループ化を解除したい
Access(アクセス)
-
18
Excel VBAからAccessマクロを実行したい
Visual Basic(VBA)
-
19
ACCESSでデータ読み取り専用を解除する方法
その他(データベース)
-
20
ACCESSでデータ変更箇所が分かるようにする方法
Access(アクセス)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
複数のCSVファイルを横に並べて...
-
VBAでCSVの1行目だけを書き換え...
-
excelインポート時の「実行時エ...
-
CSVファイルの結合(重複データ...
-
「ほかのアプリケーションを無...
-
エクセルの指数を無効にしたい
-
EXCELにcsv形式の外部データを...
-
二つのCSVファイルを照らし合わ...
-
海外の印刷所を使って入稿する...
-
大量のCSVデータを1つのエ...
-
複数のデータ系列の線の太さを...
-
VBAを一度起動するとずっと出て...
-
マクロを設定したのに、拡張子...
-
エクセルでツールバーに「縮小...
-
昨日まで動いていたエクセルの...
-
どのドキュメントは暗号化され...
-
別のパソコンでエクセルのマク...
-
excelファイルに使われているVB...
-
エクセルVBA Workbook変数に変...
-
ファイル名を今日の日付、時刻...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
複数のCSVファイルを横に並べて...
-
excelインポート時の「実行時エ...
-
「ほかのアプリケーションを無...
-
VBAでCSVの1行目だけを書き換え...
-
エクセルの指数を無効にしたい
-
複数のcsvファイルを1つのEXCEL...
-
EXCELにcsv形式の外部データを...
-
Excel2002のおせっかい機能につ...
-
複数個のascファイルを1つ...
-
Excel VBAを使った複数のCSVフ...
-
OUTLOOKのスケジュール...
-
Excelで複数の他のファイルから...
-
二つのCSVファイルを照らし合わ...
-
VB及びエクセルのVBAにて、
-
海外の印刷所を使って入稿する...
-
エクセル2003 CSVファイルの取...
-
エクセルのcsvで、12e3を入れる...
-
大量のCSVデータを1つのエ...
-
各ファイル中データの張付け操...
-
エクセルでcsvデータを自動読み...
おすすめ情報