As already noted, the short answer is "yes".
The long answer is: You can do it with a bash script that uses awk to extract the filename elements you want to base your directory structure on. It could look something like this (where more emphasis is placed on readability than "one-liner" compactness).
#!/bin/bash
for FILE in p-*
do
if [[ ! -f $FILE ]]; then continue; fi
LVL1="$(awk '{match($1,"^p-([[:digit:]]+)_[[:print:]]*",fields); print fields[1]}' <<< $FILE)"
LVL2="$(awk '{match($1,"^p-([[:digit:]]+)_n-([[:digit:]]+)_[[:print:]]*",fields); print fields[2]}' <<< $FILE)"
echo "move $FILE to p-$LVL1/n-$LVL2"
if [[ ! -d "p-$LVL1" ]]
then
mkdir "p-$LVL1"
fi
if [[ ! -d "p-$LVL1/n-$LVL2" ]]
then
mkdir "p-$LVL1/n-$LVL2"
fi
mv $FILE "p-$LVL1/n-$LVL2"
done
To explain:
- We perform a loop over all files starting with "p-" in the current directory.
- The first instruction in the loop ensures that the file exists and is a workaround for empty directories (the reason why this is necessary is that on this forum, you will always be told not to parse the output of
ls, so something likeFILES=$(ls p-*); for FILE in $FILES; do ...would be considered a no-go). - Then, we extract the numerals between
p-and_nneeded to generate the first level of your directory structure usingawk, the same for the numerals betweenn-and_afor the second level. - Third, we check if the directories for the first and second level of your intended directory structure already exist. If not, we create them.
- Last, we move the file to the target directory.
For more information, have a look at the Advanced bash scripting guide and the GNU Awk Users Guide.