• 締切済み

UTL_FILEにて既存のExcelに追加書き込みできますか?

いつもお世話になっております。 他にも質問をしており申し訳ないですが、どうしても困っておりまして新たに質問させていただきます。 UTL_FILEパッケージにて、予め用意しておいた雛形のExcelファイルに対して、入出力モード='A'にて追加書き込みしたいのですが、「PL/SQLプロシージャは正常に完了しました」は表示されますが、実際のファイルには全く追加書き込みされません。 入出力モード='W'にて新たなファイルを作成し、そのファイルに一切触れないまま、入出力モード='A'で書き込みを行うと、最終行に確かに追加されております。ただ、その新たなファイルをオープンして何か加工するとそれだけで追加書き込みができなくなるようです。 そもそも既存のExcelに追加書き込みできるものなのでしょうか? どなたかご教授いただけませんでしょうか? 宜しくお願い致します。

  • Oracle
  • 回答数2
  • ありがとう数2

みんなの回答

回答No.2

Windows版のオラクルは、PL/SQLでCOMオートメーションを利用できますので、 EXCELを起動し、セルに情報を追記することは、可能です。(標準機能) オラクルサーバにEXCELがインストールされている必要がありますけどね。 ただ、EXCELで統計資料を作成するのが目的なら、EXCEL側にVBAでオラクルデータを 読み出して、資料を作成する方が簡単かつ事例がたくさんあるように思いますよ。

ryozyryozy
質問者

お礼

ご回答ありがとうございます! COMオートメーションで色々と検索してみましたが、正直難しくてよくわかりません。なにか良いサイトか、もしよろしければサンプルコードなどをご提示いただくことは可能でしょうか? どうか宜しくお願い致します。

  • sshiba
  • ベストアンサー率69% (73/105)
回答No.1

「雛形のExcelファイル」と書いているところが気になるのですが、 その「Excelファイル」の拡張子って*.xlsですか? それとも*.xlsxとか*.csvでしょうか? *.xlsフォーマットはバイナリですし、*.xlsxもXML形式ですから、 単純にそれらの形式のファイルの後ろに追加書き込みしても Excel上では反映されませんよ。 ですから、それは「追加書き込みされていない」のではなくて、 「書き込みはされているがExcelで開いても見えていない」という話では ないかと思います。 単純にファイルの後ろに追加書き込みした結果がExcelで反映できるのは *.csvフォーマットじゃないと無理で、それ以外のフォーマットの Excelファイルを(Excelを使わずに)読み書きするためには、.NETやVB、 perl, pythonなどのプログラム開発環境向けに準備されている Excelファイルを取り扱うためのライブラリを併用する必要があります。 OracleのUTL_FILE単体だと、元々何らかのデータが入っている Excelファイルを更新するのは無理だと思いますが。

ryozyryozy
質問者

お礼

ご回答ありがとうございます! >その「Excelファイル」の拡張子って*.xlsですか? まさに*.xlsです。 >*.xlsフォーマットはバイナリですし、*.xlsxもXML形式ですから、 単純にそれらの形式のファイルの後ろに追加書き込みしても Excel上では反映されませんよ。 ですから、それは「追加書き込みされていない」のではなくて、 「書き込みはされているがExcelで開いても見えていない」という話では ないかと思います。 なるほど、そういうことだったんですね。 >Excelファイルを(Excelを使わずに)読み書きするためには、.NETやVB、 perl, pythonなどのプログラム開発環境向けに準備されている Excelファイルを取り扱うためのライブラリを併用する必要があります。 OracleのUTL_FILE単体だと、元々何らかのデータが入っている Excelファイルを更新するのは無理だと思いますが。 PL/SQLのみを使用して、簡単な統計が作れれば工数削減になるかと思って思いついたのですが、ムリなようですね。。 csvファイルに記号(===等)を使用して、枠線っぽく書いて加工するしかなさそうですね?

関連するQ&A

  • ファイルへの書き込みができない

    ファイルへの書き込みができない 実行時エラーは表示されないのですが、ファイルへ出力されません。 コードは以下のようにしています。 よろしくお願いします。 declare FILE_HANDLE utl_file.file_type; STR varchar2(1023); begin -- 書き込みモードでファイルオープン FILE_HANDLE := UTL_FILE.FOPEN('c:\tmp','test.txt','W'); STR := 'test'; -- ファイルへ出力 UTL_FILE.PUT(FILE_HANDLE,STR); -- ファイルのクローズ -- UTL_FILE.FCLOSE(FILE_HANDLE); exception when others then dbms_output.put_line('その他エラー'); end; /

  • UTL_FILEパッケージについて

    UTL_FILEパッケージを使用してPL/SQLよりテキスト出力したいのですが上手くいきません。 まずsysdbaにて「create directory aaa as 'd:\'」にてディレクトリを作成しました。 次に以下のようにプロシージャを作成しました。 create procedure kan_exp( fir IN varchar2, filename IN varchar2) is file UTL_FILE.FILE_TYPE; CURSOR tk01_kan_c IS select aaa,bbb from tableCCC begin file := UTL_FILE.FOPEN(dir, filename, 'w'); UTL_FILE.PUT_LINE(file, 'TEST'); UTL_FILE.NEW_LINE(file); for kanrec in tk01_kan_c loop UTL_FILE.PUT_LINE(file, 'TEST'); end loop; END kan_exp; / それを以下のように呼び出しましたが、 execute kan_exp('UTL_FILE_DIR', 'aaa.csv'); 「ORA-29280:無効なディレクトリパスです。」エラーが発生します。 色々と調べてユーザに権限が必要かと思い、「grant read on directory to User」としましたが、ユーザーまたはロール'User'は存在しませんと出てきます。※もちろんUserは存在します。 なにか足りないものがあるのでしょうか? ご教示いただけますでしょうか?宜しくお願いします。

  • oracle10gでのOSファイル入出力について

    こんにちは。初めて投稿させていただきます。 oracle database10gについて質問です。 PL/SQLでOSファイルの入出力を行う際、9iまではUTL_FILEパッケージを使用して行っていましたが、10gではそれに代わる機能があると以前になにかで小耳に挟んだことがあります。 ですが、WEBで検索しても、それらしきものを発見することが出来ませんでした・・・。 10gでPL/SQLからファイルを入出力する際にも、やはりUTL_FILEパッケージを使うしかないのでしょうか? OSはwindows32bitを想定しています。 つたない質問で申し訳ありませんが、回答お願いいたします。

  • PLSQLでファイルに書き込みをしたいけど出来ない。。

    ☆ とっても、初心者です。 本日、初めてのPLSQLプルグラムを書いてみました。 下記のプログラムがそうなのですが、SQL*Plusを起動し、 START XXXXXX (←作成したSQL文の名前) と書いて実行して見ましたが、エラーは出ないのですが、私の希望では、[test.ddl]ファイルにsakurakoっと出力されていて欲しいのですが、なんにも更新されていません。。。 LOG:プロシージャが作成されました。 LOG:エラーはありません。 何か方法がまずいのでしょうか? あぁぁ、、何方かよきアドバイスをお願い致します。 ===================================== CREATE OR REPLACE PROCEDURE Create_US_Company IS CURSOR WORK_LINE IS SELECT * FROM TEST.US_COMPANY; TYPE FILE_TYPE IS RECORD (ID BINARY_INTEGER); FILE_HANDLE UTL_FILE.FILE_TYPE := UTL_FILE.FOPEN('D:\tmp,'test.ddl','w'); STR VARCHAR2(200); BEGIN STR := 'SAKURAKO'; UTL_FILE.PUT_LINE ( FILE_HANDLE, STR); UTL_FILE.FCLOSE (FILE_HANDLE); END Create_US_Company; ===================================== ☆

  • UTL_FILE_DIRについて

    お世話になっております。 PL/SQLのファイル出力を行おうとUTL_FILE_DIRを組んだのですがファイルが更新されません。 エラーも検出されないのでどうしたものかと悩んでおります。 ソースは一番最後に記載します。 現状のやった作業に関しては ・初期化パラメータにUTL_FILE_DIR = * selectで確認済み ・テキストファイルの確認  ソースに記載してる通りの所に存在している。(権限もフルコン) oracleのバージョンは9iです。 よろしくお願いします。 set serveroutput on; DECLARE -- ファイルハンドラ vHandle UTL_FILE.FILE_TYPE;   vDirname      VARCHAR2(250);   vFilename      VARCHAR2(250); vOutput VARCHAR2(32767); error_code       NUMBER(5); error_message VARCHAR2(2048); BEGIN vDirname := 'c:'; vFilename := 'test.txt'; vHandle := UTL_FILE.FOPEN(vDirname, vFilename, 'w'); vOutput := ファイル出力です'; UTL_FILE.PUT_LINE(vHandle, vOutput); UTL_FILE.FCLOSE(vHandle); EXCEPTION WHEN OTHERS THEN error_code := sqlcode; error_message := sqlerrm; dbms_output.put_line('エラーコード:' || error_code); dbms_output.put_line('エラーメッセージ:' || error_message); END; / 上記実行するとエラー無しで正常終了しますがテキストファイルは更新されていません。

  • Oracle10gのUTL_FILEについて

    Win2000 Oracle10gにて、 PL/SQLのUTL_FILEパッケージを使用して、 TEXTファイルを操作しようとしています。 ところが、FOPEN時、 ORA-29280: 無効なディレクトリ・パスです。 となってしまいます。 Oracleのsysユーザにて、 ディレクトリオブジェクトを作成し、 READ,WRITE権限をPUBLICに与えました。 これで出来そうなのですが…。 なぜにできないのでしょうか? どなたか解決方法をご存知ではないですか・

  • PL/SQLでファイルのコピー&削除

    PL/SQLで実ファイルのコピーや削除はできないのでしょうか? 読込や書出しはUTL_FILEパッケージでできることまでは分かったのですが どうしてもコピー&削除が出来るかどうか調べきれません。 もし、できるのであればヒントでもかまいませんのでご指導願えませんか? よろしくお願いします

  • UTL_FILEエラー?

    Oracle10g(リンクをはっています) Winxp http://oshiete1.goo.ne.jp/kotaeru.php3?q=995849 を参考にして以下のようなプロシージャを作成しました。 CREATE OR REPLACE PROCEDURE test.Test_Convrt IS BEGIN DECLARE c1 number; c2 number; data1 varchar2(100) := null; data2 varchar2(100) := null; File_Handle UTL_FILE.FILE_TYPE; Read_Line VARCHAR2(1023); BEGIN File_Handle := utl_file.fopen('C:\temp', 'test.csv', 'r'); LOOP BEGIN UTL_FILE.GET_LINE(File_Handle, Read_line); -- カンマ位置 c1 := instr(Read_line,',',1,1); c2 := instr(Read_line,',',1,2); -- 列データ data1 := ltrim(substr(Read_line,1 ,c1-1)); data2 := ltrim(substr(Read_line,c1+1,c2-c1-1)); -- update update test.tbl1 set col1= data2 where col1= data1; commit; exception when no_data_found then exit; END; END LOOP; UTL_FILE.FCLOSE(File_Handle); END; END ; コンパイルは通るのですが、いざ実行しようとすると、 行1でエラーが発生しました。 : ORA-29280:invalid directory path ORA-06512 at "SYS.UTL_FILE", line 33 ORA-06512 at "SYS.UTL_FILE", line 436 ORA-06512 at "test.TEST_CONVRT", line 11 ORA-06512 at line 1 と表示されました。 http://oshiete1.goo.ne.jp/kotaeru.php3?q=1338675 も見てみたのですが、初心者なので、いまひとつ理解できません。 SYS.UTL_FILEを参照できていないということはなんとなく、わかりました。 どのようにすれば解決できるでしょうか? また、開発初心者なので、参考になるサイトが知りたいです。 どなたか、よろしくお願いします。

  • ORACLEのUTL_FILEパッケージについて

    皆さん、いつもありがとうございます。 OracleのUTL_FILEパッケージを使ったのですが うまくいきません。 どなたか教えてください。 よろしくお願いします。 目的) UTL_FILEパッケージを使ってファイルを作成したい 出力先はネットワークにある共有フォルダーです。 質問) ファイルの書き込み先をネットワークドライブまたは 他の端末(\\コンピュータ名\共有フォルダー)した時 以下のエラーになります。出力先を自端末にした場合は うまくいきます。ちなみに初期パラには「UTL_FILE_DIR = *」 と記述してOracleの再起動もしております。 エラーメッセージ : User-Defined Exception 以上です。

  • CSVファイルを読み込んでテーブルの更新

    こんばんは。 oracle9iでPL/SQLを使用して、CSVファイルを 読み込んで、テーブルの更新を行いたいと 思っています。 CSVファイル、テーブル共に最初の2つがキー項目です。 ■CSVファイル 001, 111, 10000, 20000 002, 222, 30000, 40000 ・・・・・ ・・・・・ 009, 999, 55555, 55555 ■テーブル 001, 111, 99999, 99999 002, 222, 99999, 99999 ・・・・・ ・・・・・ 009, 999, 99999, 99999 ■テーブル(処理後) 001, 111, 10000, 20000 002, 222, 30000, 40000 ・・・・・ ・・・・・ 009, 999, 55555, 55555 わかったのは、CSVファイルを行単位で読み込む所までです。 DECLARE   File_Handle UTL_FILE.FILETYPE; Read_Line VARCHAR2(1023); BEGIN File_Handle := UTL.FILE.FOPEN('dir', 'file', 'r'); BEGIN LOOP UTL.FILE.GETLINE(File_Handle, Read_line); END LOOP; END; UTL.FILE.FCLOSE(File_Handle); END; 1行を読み込んだのはいいけど、この後がよくわかりません。テーブルを更新する所とあわせて、ご教示ください。