Portál AbcLinuxu, 6. května 2025 09:23
Ř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 / _\`\'" \; |bashA 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.