Linux.com

addihetja

addihetja

  • Linux.com Member
  • Posts: 1
  • Member Since: 24 Feb 11
  • Last Logged In: 15 Mar 11

Latest Posts

Posted by
Topic
Post Preview
Posted
  • addihetja
    Comparing contents of two directories using bash
    I need help figuring out how I write a script that copies files that exist in one directory but don't exist in the second directory to the third directory. I have the following scenario: Files are uploaded from time to time to a directory. These are jpg, pdf, swf and a bunch of different files. The files are then processed via script (pdfs are processed using imagemagick, jpgs copied to a certain directory and the names shortened and so forth) that is working very well. This is in part the reason for I need to change the workflow: The original file names cannot be compared to the output filenames. The whole process can take hours since we're talking about thousands of files. The processing of the files (thousands) can take hours so I thought I'd change the workflow: Create a script that would compare files from the "1-incoming" and "0-processed" directories and copy the files that haven't been processed (files that exist in "1-incoming" but not in "0-processed" to a directory called "2-toDo" but I am at a total loss how I would do that. Here is an example: rootpath=/home/test/files The contents of which are: 0-processed/ 1-incoming/ 2-toDo/ 3-toPDF/ 4-toTruncate/ 5-truncated/ 6-toOutput/ With no files processed the "0-processed" directory is empty so what currently happens is that everything gets processed like this: a) A script copies everything that exists in 1-incoming directory but doesn't exist in 0-processed to 2-toDo b) A second script copies PDFs from 2-toDo to 3-toPDF and other files straight to 4-toTruncate c) A third script uses imageMagick to convert PDFs to JPG files and copies the JPGs to 4-toTruncate and the PDFs to 0-processed d) A fourth script copies the files in 4-toTruncate to 5-truncated under a shorter name and the original files to 0-processed e) A fifth script copies files in 5-truncated to 6-toOutput f) A sixth script copies the files in 6-toOutput to another server I know that the last two steps can be joined in one step but I chose to write it up like this to make the example more clear. I basically need help with step a) Can anyone give me pointers as to how I would do this using bash? A.
    Link to this post 24 Feb 11

    I need help figuring out how I write a script that copies files that exist in one directory but don't exist in the second directory to the third directory.

    I have the following scenario:
    Files are uploaded from time to time to a directory. These are jpg, pdf, swf and a bunch of different files.
    The files are then processed via script (pdfs are processed using imagemagick, jpgs copied to a certain directory and the names shortened and so forth) that is working very well. This is in part the reason for I need to change the workflow: The original file names cannot be compared to the output filenames. The whole process can take hours since we're talking about thousands of files.

    The processing of the files (thousands) can take hours so I thought I'd change the workflow:
    Create a script that would compare files from the "1-incoming" and "0-processed" directories and copy the files that haven't been processed (files that exist in "1-incoming" but not in "0-processed" to a directory called "2-toDo" but I am at a total loss how I would do that.

    Here is an example:
    rootpath=/home/test/files

    The contents of which are:
    0-processed/
    1-incoming/
    2-toDo/
    3-toPDF/
    4-toTruncate/
    5-truncated/
    6-toOutput/

    With no files processed the "0-processed" directory is empty so what currently happens is that everything gets processed like this:
    a) A script copies everything that exists in 1-incoming directory but doesn't exist in 0-processed to 2-toDo
    b) A second script copies PDFs from 2-toDo to 3-toPDF and other files straight to 4-toTruncate
    c) A third script uses imageMagick to convert PDFs to JPG files and copies the JPGs to 4-toTruncate and the PDFs to 0-processed
    d) A fourth script copies the files in 4-toTruncate to 5-truncated under a shorter name and the original files to 0-processed
    e) A fifth script copies files in 5-truncated to 6-toOutput
    f) A sixth script copies the files in 6-toOutput to another server

    I know that the last two steps can be joined in one step but I chose to write it up like this to make the example more clear.

    I basically need help with step a)

    Can anyone give me pointers as to how I would do this using bash?

    A.

Who we are ?

The Linux Foundation is a non-profit consortium dedicated to the growth of Linux.

More About the foundation...

Frequent Questions

Join / Linux Training / Board