2012-04-04 15 views
9

Ten wpis pojawia się na około 80% tego, co chcę zrobić, ale nic nie mam wymyślić pracuje: bash: how to delete elements from an array based on a patternBash: Usuwanie elementów znajdujących się w jednym szeregu z innymi

Mam dwie tablice:

@tapes_in_drives=(SP1026,SP0995,SP0434) 

@tapes=(SP0001,SP0002,SP0434,SP0995,SP1026,SP2000,SP3000) 

Potrzebuję rozwiązania bash, które może usunąć wszystkie wpisy obecne w @tapes_in_drives z @tapes.

buduję skrypt do automatyzacji wyrzucania taśmy z biblioteki taśm w oparciu o daty ważności itp

Próbowałem to:

for i in "${tapes_in_drives[@]}"; do 
     tapes=(${tapes[@]//*$i*}) 
done 

ale to nie działa, nic nie jest oddalony.

Dziękujemy za pomoc.

EDIT:

Oto kod używam, napisałem to w Perlu pierwotnie, stąd @zmienna definicje i byłem bardzo zmęczony, gdy pisałem tę kwestię.

kod:

#!/usr/bin/bash 

# If media expires less than this many days, keep it 
export days_expired="30" 

# Set to 1 to get debug output to console 
export debug="1" 

# Get list of SPxxxxx tapes that are physically in the library 
if [ $debug -eq 1 ]; then echo "Getting tape list"; fi 
export tapes=`vmquery -rn 1 -b | tail +4 | awk '{print \$1}' && vmquery -rn 4 -b | tail +4 | awk '{print \$1}'` 

if [ $debug -eq 1 ]; then echo ${tapes[@]}; fi 

# Query tape drives for tapes 
export tapes_in_drives=`ssh srv-reg-nbms-01 "echo 's d q'|/usr/openv/volmgr/bin/tldtest -r /dev/smc0|grep 'Barcode'" | awk '{print $3}' && ssh srv-reg-nbms-02 "echo 's d q'|/usr/openv/volmgr/bin/tldtest -r /dev/smc0|grep 'Barcode'" | awk '{print $3}'` 

if [ $debug -eq 1 ]; then 
    echo "" 
    echo "Tapes in Drives:" 
    echo ${tapes_in_drives[@]} 
    echo ""; 
fi 


# Remove tapes in drives from list of tapes 
for i in "${tapes_in_drives[@]}"; do 
    tapes=(${tapes[@]//*$i*}) 
done 

echo "Tape List 2" 
echo ${tapes[@]} 

Wyniki:

Pierwsze lista taśma

SP0011 SP0039 SP0402 SP0434 SP0464 SP0516 SP0551 SP0600 SP0604 SP0726 SP0731 SP0765 SP0767 SP0779 SP0781 SP0787 SP0793 SP0794 SP0805 SP0828 SP0830 SP0832 SP0927 SP0928 SP0936 SP0983 SP0995 SP1001 SP1004 SP1008 SP1015 SP1017 SP1026 SP1033 SP1036 SP1038 SP0042 SP0049 SP0150 SP0462 SP0473 SP0517 SP0557 SP0560 SP0642 SP0659 SP0697 SP0712 SP0723 SP0766 SP0777 SP0786 SP0788 SP0792 SP0907 SP0910 SP0923 SP0925 SP0926 SP0940 SP0963 SP0981 SP0986 SP0989 SP0994 SP0999 SP1007 SP1020 SP1021 SP1027 SP1039

Tapes w napędach:

SP1001 SP1038 SP0923 SP0926 SP0925

Lista Tape 2

SP0011 SP0039 SP0402 SP0434 SP0464 SP0516 SP0551 SP0600 SP0604 SP0726 SP0731 SP0765 SP0767 SP0779 SP0781 SP0787 SP0793 SP0794 SP0805 SP0828 SP0830 SP0832 SP0927 SP0928 SP0936 SP0983 SP0995 SP1001 SP1004 SP1008 SP1015 SP1017 SP1026 SP1033 SP1036 SP1038 SP0042 SP0049 SP0150 SP0462 SP0473 SP0517 SP0557 SP0560 SP0642 SP0659 SP0697 SP0712 SP0723 SP0766 SP0777 SP0786 SP0788 SP0792 SP0907 SP0910 SP0923 SP0925 SP0926 SP0940 SP0963 SP0981 SP0986 SP0989 SP0994 SP0999 SP1007 SP1020 SP1021 SP1027 SP1039

Jak widać, nazwy taśm z tapes_in_drives nie są usuwane z tablicy taśm.

+0

Co z Twojego rozwiązania? Próbowałem, oczywiście naprawiając błędy składniowe i wydaje się, że działa. – C2H5OH

+0

dlaczego używasz "@" na początku nazw zmiennych? Nie sądzę, że jest to poprawny znak dla nazwy zmiennej. Powodzenia. – shellter

Odpowiedz

12

Jak powiedział komentarz, to tylko błędy składniowe.

Oddzielaj spacją wpisy tablicy, nie używaj @, a funkcja jest odpowiednia dla przykładowych danych. Zauważ, że usuwa on dowolny wpis zawierający wpis w tapes_in_drives, a nie tylko te, które dokładnie pasują do wpisu.

tapes=(SP0001 SP0002 SP0434 SP0995 SP1026 SP2000 SP3000) 
tapes_in_drives=(SP1026 SP0995 SP0434) 
for i in "${tapes_in_drives[@]}"; do 
     tapes=(${tapes[@]//*$i*}) 
done 

Wyniki:

$ echo ${tapes[0]} 
SP0001 
$ echo ${tapes[1]} 
SP0002 
$ echo ${tapes[2]} 
SP2000 
$ echo ${tapes[3]} 
SP3000 
$ echo ${tapes[4]} 

$ 

EDIT odpowiedzieć na edycji w pytaniu

Linia:

export tapes=`vmquery -rn 1 -b | tail +4 | awk '{print \$1}' && vmquery -rn 4 -b | tail +4 | awk '{print \$1}'` 

I ta linia:

export tapes_in_drives=`ssh srv-reg-nbms-01 "echo 's d q'|/usr/openv/volmgr/bin/tldtest -r /dev/smc0|grep 'Barcode'" | awk '{print $3}' && ssh srv-reg-nbms-02 "echo 's d q'|/usr/openv/volmgr/bin/tldtest -r /dev/smc0|grep 'Barcode'" | awk '{print $3}'` 

Inicjalizacja tapes i tapes)in_drives jako ciągi, a nie tablice. Musisz dodać nawiasy wokół przypisanej wartości, aby przekształcić je w tablice, lub pętla nie zadziała. Możesz także upuścić export, nie jest to konieczne, chyba że chcesz, aby procesy tworzone przez skrypt dziedziczyły te zmienne powłoki jako zmienne środowiskowe.

tapes=(`vmquery -rn 1 -b | tail +4 | awk '{print \$1}' && vmquery -rn 4 -b | tail +4 | awk '{print \$1}'`) 

tapes_in_drives=(`ssh srv-reg-nbms-01 "echo 's d q'|/usr/openv/volmgr/bin/tldtest -r /dev/smc0|grep 'Barcode'" | awk '{print $3}' && ssh srv-reg-nbms-02 "echo 's d q'|/usr/openv/volmgr/bin/tldtest -r /dev/smc0|grep 'Barcode'" | awk '{print $3}'`) 
+0

Idealny! To rozwiązuje mój problem! Dziękuję Ci! – user708516

4

Innym rozwiązaniem:

tapes_in_drives=(SP1026 SP0995 SP0434) 
tapes=(SP0001 SP0002 SP0434 SP0995 SP1026 SP2000 SP3000) 

tps=" ${tapes[*]} "      # stringify the array 

for item in ${tapes_in_drives[@]}; do 
    tps=${tps/ ${item}/}    # replace item 
done 
tapes=($tps)       # replace the array 
Powiązane problemy