• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 1232
  • Last Modified:

How to detect zero byte files in Windows

I need a method (vb script / batch file) to detect a zero byte text file with in a folder.  We using both XP and Windows 2003 machines to recieve many text files via ftp.  After the files are recieved they are processed by a mapping program.  When a zero byte file is processes by the mapping program the program fails.  

I need a script / batch file to detect the zero byte text files and then delete them.
0
epmmis
Asked:
epmmis
4 Solutions
 
johnb6767Commented:
dir C:\Folder\test.bmp | find " 1 File(s)              0 bytes" && echo File is ZERO Bytes......

Simply returns "File is ZERO Bytes......"

Or set a variable etc.....

Keep the spacing as is... I'm sure there is a more graceful method than this batch...........


0
 
AlexPaceCommented:
Another option is to use a scriptable FTP server.  For example, if you used Robo-FTP Server you write a short script that is triggered by the UploadComplete event.  The script would check the size of the uploaded file and delete it if the length is 0 bytes.
0
 
RobSampsonCommented:
This would work in VBScript.

Regards,

Rob

strFolder = "C:\Files"
Set objFSO = CreateObject("Scripting.FileSystemObject")
For Each objFile In objFSO.GetFolder(strFolder).Files
   If objFile.Size = 0 Then objFile.Delete True
Next

Open in new window

0
Veeam and MySQL: How to Perform Backup & Recovery

MySQL and the MariaDB variant are among the most used databases in Linux environments, and many critical applications support their data on them. Watch this recorded webinar to find out how Veeam Backup & Replication allows you to get consistent backups of MySQL databases.

 
johnb6767Commented:
Yeah, prettier indeed...
0
 
sjklein42Commented:
This DOS command scans the current folder for zero-length files and deletes them.

for %i in (*) do @if "%~zi"=="0" del "%i"

Open in new window


Note that if you use this in a batch file, you need to double-up the percent signs.
0
 
epmmisAuthor Commented:
Thank AlexPace. We do use RoboFTP as our FTP client.  RoboFTP tech support provided this solution.

Are these zero byte files downloaded from a remote site or do they come from somewhere else?  If they come from the site then maybe it would be easier to use FTPGETFILE or GETSITEFILE to set the value of the %sitefilesize variable and then only download the files with more than 0 bytes.  If the files have a local or unknown source you could add a little loop at the bottom of your script that uses GETNEXTFILE to set the %nextfilesize variable and then get rid of the zero byte files.
If you use these commands in a loop that deletes or renames files you'll need to use GETREWIND or FTPGETREWIND after deleting or renaming a file.  This starts the loop over at the top so it is inefficient but shouln't cause any preceptable delay unless the folders you are processing contain hundreds of files.  The reason this is necessary is that, internally, these command keep track of which file they are processing by noting its ordinal position within the directory listing.  Deleting or renaming files changes the order of the directory listing so the command gets confused if, for example, the file that WAS the 3rd file is now the 4th file.
Here is an example of using GETFILE in a loop to delete local 0 byte files:
GETREWIND
:fetch_file_stats
GETFILE "*"
IFERROR= $ERROR_NO_FILE_FOUND GOTO no_more_files
IFNUM> %nextfilesize 0 GOTO fetch_file_stats
DELETE %nextfile
GETREWIND
GOTO fetch_file_stats
:no_more_files

The rest of the answers were good too.  So you all get points for the exceptional answers.
0

Featured Post

Nothing ever in the clear!

This technical paper will help you implement VMware’s VM encryption as well as implement Veeam encryption which together will achieve the nothing ever in the clear goal. If a bad guy steals VMs, backups or traffic they get nothing.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now