Portál AbcLinuxu, 4. listopadu 2025 04:45
Řešení dotazu:
cd '/zdrojový/adresář'
for dir in {A..B}{1..12}; do
  cp "${dir}/assembly.fa" '/cílový/adresář/'"${dir}assembly.fa"
done
            Tohle^^^ tedy samozřejmě předpokládá, že jsou všechny ty adresáře v jednom a tom samém společném adresáři. Tady je jednoduchý ilustrativní příklad / test:
mkdir nějaký_pokus cíl
cd nějaký_pokus
mkdir {A..B}{1..12}
touch {A..B}{1..12}/assembly.fa
cd ..
for dir in {A..B}{1..12}; do
  cp "nějaký_pokus/${dir}/assembly.fa" "cíl/${dir}assembly.fa"
done
ls -l cíl
rm -Rf nějaký_pokus cíl
            Pokud ty adresáře můžou být libovolně vnořené v jiných adresářích, tak třeba takto:
find zdroj -type d -regextype awk -regex '.*[AB](1[0-2]?|[2-9])' \
| while read dir; do
    cp "${dir}/assembly.fa" "cíl/$(basename "${dir}")assembly.fa"
  done
Opět ukázka s triviálním testem (která sice netestuje hlubší zanoření adresářů, protože jsem extrémně líný, ale mělo by to i s hlubším zanořením fungovat):
mkdir 'zdroj' 'cíl'
mkdir 'zdroj/'{A..B}{1..12}
touch 'zdroj/'{A..B}{1..12}'/assembly.fa'
find zdroj -type d -regextype awk -regex '.*[AB](1[0-2]?|[2-9])' \
| while read dir; do
    cp "${dir}/assembly.fa" "cíl/$(basename "${dir}")assembly.fa"
  done
ls -l 'cíl'
rm -Rf 'zdroj' 'cíl'
            KAM=""; Z=""; find $Z -name "assembly.fa" -exec echo "cp -v '{}' $KAM/\'\`echo {}|tr / _\`\'" \; |bash
A u mna "demo" (pouzil som absolutne cesty, mozes pouzit i relativne):
$ KAM="/tmp/kam"; Z="/tmp/z/"; find $Z -name "assembly.fa" -exec echo "cp -v '{}' $KAM/\'\`echo {}|tr / _\`\'" \; |bash 
'/tmp/z/b/assembly.fa' -> "/tmp/kam/'_tmp_z_b_assembly.fa'"
'/tmp/z/a/assembly.fa' -> "/tmp/kam/'_tmp_z_a_assembly.fa'"
$ 
            rename 's/\///' */assembly.fa
echo "nazdar honzo" | sed 's/nazdar/ahoj/'Pokud by se meli zmeni vsechny vyskyty na radku, pridas na konec g: 's/neco/zaneco/g'
To je skript pro sed (stream editor). Úvodní s znamená nahrazení (substitute) a pak následují dva výrazy oddělené (v tomto případě) lomítky, první je regulární výraz a druhý je šablona k nahrazení. Nelze než doporučit manuálové stránky, protože tohle vyžaduje pochopení rour (pipe) a regulárních výrazů.
Ještě bych doplnil, že pro jednoduché případy umí přesně tohle i samotný shell při expanzi proměnných a není tedy nezbytně potřeba další proces.
text='aabbcc'
echo "${text}"          # aabbcc
echo "${text/b/z}"      # aazbcc
echo "${text//b/z}"     # aazzcc
echo "${text/[ac]/z}"   # zabbcc
echo "${text/%[ac]/z}"  # aabbcz
echo "${text//[ac]/z}"  # zzbbzz
Význam jednotlivých znaků je popsaný v man bash, kapitola Expansion / Parameter Expansion.
… shopt -s extglob …
Žádný z mnou uvedených příkladů nevyžaduje extglob, pokud se nepletu. Ten bývá většinou implicitně zapnutý, ale aby ho člověk fakt využil, musel by tam jako pattern zapsat něco z tohoto:
       If  the  extglob  shell option is enabled using the shopt builtin, several
       extended pattern matching operators  are  recognized.   In  the  following
       description, a pattern-list is a list of one or more patterns separated by
       a |.  Composite patterns may be formed using one or more of the  following
       sub-patterns:
              ?(pattern-list)
                     Matches zero or one occurrence of the given patterns
              *(pattern-list)
                     Matches zero or more occurrences of the given patterns
              +(pattern-list)
                     Matches one or more occurrences of the given patterns
              @(pattern-list)
                     Matches one of the given patterns
              !(pattern-list)
                     Matches anything except one of the given patterns
            On to ale chtěl zkopírovat, zatímco rename všechno přesouvá (jako mv).
        Tiskni
            
                Sdílej:
                
                
                
                
                
                
            
    
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.