DeleteFile

ActiveBasicでのプログラミングでわからないこと、困ったことなどがあったら、ここで質問してみましょう(質問を行う場合は、過去ログやWeb上であらかじめ問題を整理するようにしましょう☆)。
返信する
メッセージ
作成者
TISAproject
記事: 62
登録日時: 2016年9月24日(土) 15:35

DeleteFile

#1 投稿記事 by TISAproject »

DeleteFile ( "C:\a\a.txt" )

フォルダーとファイル、どちらも削除できるようにするにはどうすればいいでしょうか?
たかせ
記事: 215
登録日時: 2006年2月05日(日) 17:10
お住まい: 東京都

Re: DeleteFile

#2 投稿記事 by たかせ »

処理方法として
まず該当ディレクトリー内をWIN32 API FindFirstFileでファイルを検索します
エラーになるまで以下の①と②の処理を繰り返します
 ①WIN32 API DeleteFileでファイルを削除します
 ②WIN32 API FindNextFileで次のファイルを検索します
WIN32 API FindCloseで該当ディレクトリーをクローズします
WIN32 API RemoveDirectoryで空のディレクトリーを削除します
以上です
TISAproject
記事: 62
登録日時: 2016年9月24日(土) 15:35

Re: DeleteFile

#3 投稿記事 by TISAproject »

do
alls = DeleteFile ( A & "")
FindNextFile
loop on error go to

"FindNextFile" のパラメータ指定が間違っています

となってしまうのですが・・・
たかせ
記事: 215
登録日時: 2006年2月05日(日) 17:10
お住まい: 東京都

Re: DeleteFile

#4 投稿記事 by たかせ »

上記の件のサンプルです。

CONST CRLF = EX"\r\n"
DIM ACCSBYTE AS DWord
DIM DAT AS WIN32_FIND_DATA
DIM HFILED AS HANDLE
DIM PATH[255] AS Char
HFILED = FindFirstFile("D:\APPLTEST\A\*.TXT",DAT)
DO
IF HFILED = INVALID_HANDLE_VALUE THEN
MessageBox(NULL,"削除データがありませんでした。","TEST",MB_OK)
EXIT DO
END IF
lstrcpy(PATH,"D:\APPLTEST\A\")
lstrcat(PATH,DAT.cFileName)
IF DeleteFile(PATH) = 0 THEN
MessageBox(NULL,"DeleteFileエラー発生しました。","TEST",MB_OK)
ELSE
lstrcat(PATH,"を削除しました。")
MessageBox(NULL,PATH,"TEST",MB_OK)
END IF
LOOP UNTIL FindNextFile(HFILED,DAT) = 0
FindClose(HFILED)
RemoveDirectory("D:\APPLTEST\A")
MessageBox(NULL,"処理終了しました。","TEST",MB_OK)
END

WIN32 APIについての詳細はABのヘルプに載っていると思いますのでご確認下さい。
TISAproject
記事: 62
登録日時: 2016年9月24日(土) 15:35

Re: DeleteFile

#5 投稿記事 by TISAproject »

削除対象フォルダーの中にフォルダーが入っていると、削除できないのですが、どうすればいいですか?
イグトランス
記事: 899
登録日時: 2005年5月31日(火) 17:59
お住まい: 東京都
連絡する:

Re: DeleteFile

#6 投稿記事 by イグトランス »

API関数のSHFileOperationを使うと、ファイル・フォルダの区別無く、またフォルダの中にファイルがあっても削除できます。

コード: 全て選択

#console

Dim fos As SHFILEOPSTRUCT
fos.wFunc = FO_DELETE
fos.pFrom = Ex"D:\\a\0"
fos.fFlags = FOF_SILENT Or FOF_NOCONFIRMATION Or FOF_NOERRORUI

If SHFileOperation(fos) = 0 And fos.fAnyOperationsAborted = FALSE Then
	Print "削除しました。"
Else
	Print "削除できませんでした。"
End If
pFromには、Ex文字列で、最後に\0を付け足す必要があります。この例だとD:\にあるaを削除しようとしています。
TISAproject
記事: 62
登録日時: 2016年9月24日(土) 15:35

Re: DeleteFile

#7 投稿記事 by TISAproject »

コード: 全て選択

Dim A1 As string
fos.pFrom = Ex A1
にするとエラーが発生してしまいます。
たかせ
記事: 215
登録日時: 2006年2月05日(日) 17:10
お住まい: 東京都

Re: DeleteFile

#8 投稿記事 by たかせ »

TISAproject さんが書きました:

コード: 全て選択

Dim A1 As string
fos.pFrom = Ex A1
にするとエラーが発生してしまいます。
Ex表記について変数には使用できません。
ABのヘルプを確認してみてください。
なので下記の様な記載で問題ないと思いますが
fos.pFrom = Ex"D:\\a\0"
イグトランス
記事: 899
登録日時: 2005年5月31日(火) 17:59
お住まい: 東京都
連絡する:

Re: DeleteFile

#9 投稿記事 by イグトランス »

そうですね。Ex文字列では、直接ソースコードに書く以外の方法で使いづらいのでした。

Ex"\0"以外の方法(String型変数に対して使える方法)としてChr$(0)を連結する方法があります。こうするのはどうでしょうか。

コード: 全て選択


#console

Dim A1 As String
A1 = "T:\a"

Dim deletePath As String
deletePath = A1 + Chr$(0)

Dim fos As SHFILEOPSTRUCT
fos.wFunc = FO_DELETE
fos.pFrom = StrPtr(deletePath)
fos.fFlags = FOF_SILENT Or FOF_NOCONFIRMATION Or FOF_NOERRORUI

If SHFileOperation(fos) = 0 And fos.fAnyOperationsAborted = FALSE Then
	Print "削除しました。"
Else
	Print "削除できませんでした。"
End If
TISAproject
記事: 62
登録日時: 2016年9月24日(土) 15:35

Re: DeleteFile

#10 投稿記事 by TISAproject »

たかせ様
イグトランス様

本当にご協力ありがとうございます。
皆様のおかげでいろいろな知識が蓄えられました!
返信する