linux shell中基本所有的命令操作都有返回值的,一般操作成功會返回0,失敗會返回1
可以使用 $? 這個環境變數得到上一個命令的返回值,解壓也一樣
解壓後,輸入命令 echo $? 就可以得到返回值了,如0則為成功,1說明失敗了
2. shell腳本壓縮解壓
tar cjf /mnt/sdcard/tmp/1.tar /mnt/sdcard/TitianiumBackup/
tar xvf /mnt/sdcard/tmp/1.tar
3. 如何同shell腳本獲取剛生成的文件並進行解壓呢
#!/bin/sh
filename=$1
dirname=`basename $filename .tar.gz`
if [ -z $1 ];then
echo Usage $0 filename
exit 1
fi
scp [email protected]:/opt/$file /opt
cd /opt
tar zxf $filename
pushd $dirname
find . -type f -name "*.zip" -exec unzip {} \;
find . -type f -name "*.rar" -exec unrar {} \;
popd
4. 求shell下載解壓腳本
#!/bin/sh
filename=$1
dirname=`basename $filename .tar.gz`
if [ -z $1 ];then
echo Usage $0 filename
exit 1
fi
scp [email protected]:/opt/$file /opt
cd /opt
tar zxf $filename
pushd $dirname
find . -type f -name "*.zip" -exec unzip {} \;
find . -type f -name "*.rar" -exec unrar {} \;
popd
5. 用shell解壓zip,沒反應是怎麼回事 我想解壓system/a/b.zip 代碼這樣寫的
等我明天上班。file system/a/b.zip的結果得是zip文件才可以的。
明天搞個實驗,就知道了。b.zip只是個名字,必須是zip格式的文件,unzip才有用
6. shell 判斷解壓成功
檢測返回值就可以了。
tarxvffile.tar&&echo"解壓成功"
或者
iftarxvffile.tar;then
echo"解壓成功"
fi
7. linux解壓命令tar
tar
-c: 建立壓縮檔案
-x:解壓
-t:查看內容
-r:向壓縮歸檔文件末尾追加文件
-u:更新原壓縮包中的文件
這五個是獨立的命令,壓縮解壓都要用到其中一個,可以和別的命令連用但只能用其中一個。下面的參數是根據需要在壓縮或解壓檔案時可選的。
-z:有gzip屬性的
-j:有bz2屬性的
-Z:有compress屬性的
-v:顯示所有過程
-O:將文件解開到標准輸出
下面的參數-f是必須的
-f: 使用檔案名字,切記,這個參數是最後一個參數,後面只能接檔案名。
# tar -cf all.tar *.jpg
這條命令是將所有.jpg的文件打成一個名為all.tar的包。-c是表示產生新的包,-f指定包的文件名。
# tar -rf all.tar *.gif
這條命令是將所有.gif的文件增加到all.tar的包裡面去。-r是表示增加文件的意思。
# tar -uf all.tar logo.gif
這條命令是更新原來tar包all.tar中logo.gif文件,-u是表示更新文件的意思。
# tar -tf all.tar
這條命令是列出all.tar包中所有文件,-t是列出文件的意思
# tar -xf all.tar
這條命令是解出all.tar包中所有文件,-t是解開的意思
壓縮
tar -cvf jpg.tar *.jpg //將目錄里所有jpg文件打包成tar.jpg
tar -czf jpg.tar.gz *.jpg //將目錄里所有jpg文件打包成jpg.tar後,並且將其用gzip壓縮,生成一個gzip壓縮過的包,命名為jpg.tar.gz
tar -cjf jpg.tar.bz2 *.jpg //將目錄里所有jpg文件打包成jpg.tar後,並且將其用bzip2壓縮,生成一個bzip2壓縮過的包,命名為jpg.tar.bz2
tar -cZf jpg.tar.Z *.jpg //將目錄里所有jpg文件打包成jpg.tar後,並且將其用compress壓縮,生成一個umcompress壓縮過的包,命名為jpg.tar.Z
rar a jpg.rar *.jpg //rar格式的壓縮,需要先下載rar for linux
zip jpg.zip *.jpg //zip格式的壓縮,需要先下載zip for linux
解壓
tar -xvf file.tar //解壓 tar包
tar -xzvf file.tar.gz //解壓tar.gz
tar -xjvf file.tar.bz2 //解壓 tar.bz2
tar -xZvf file.tar.Z //解壓tar.Z
unrar e file.rar //解壓rar
unzip file.zip //解壓zip
總結
1、*.tar 用 tar -xvf 解壓
2、*.gz 用 gzip -d或者gunzip 解壓
3、*.tar.gz和*.tgz 用 tar -xzf 解壓
4、*.bz2 用 bzip2 -d或者用bunzip2 解壓
5、*.tar.bz2用tar -xjf 解壓
6、*.Z 用 uncompress 解壓
7、*.tar.Z 用tar -xZf 解壓
8、*.rar 用 unrar e解壓
9、*.zip 用 unzip 解壓
解壓jdk到指定文件夾:
tar -xzvf jdk-8u131-linux-x64.tar.gz -C /usr/local/java
root@ubuntu:~# tar --help
用法: tar [選項...] [FILE]...
GNU 'tar' saves many files together into a single tape or disk archive, and can
restore indivial files from the archive.
Examples:
tar -cf archive.tar foo bar # Create archive.tar from files foo and bar.
tar -tvf archive.tar # List all files in archive.tar verbosely.
tar -xf archive.tar # Extract all files from archive.tar.
主操作模式:
-A, --catenate, --concatenate 追加 tar 文件至歸檔
-c, --create 創建一個新歸檔
-d, --diff, --compare 找出歸檔和文件系統的差異
--delete 從歸檔(非磁帶!)中刪除
-r, --append 追加文件至歸檔結尾
-t, --list 列出歸檔內容
--test-label 測試歸檔卷標並退出
-u, --update 僅追加比歸檔中副本更新的文件
-x, --extract, --get 從歸檔中解出文件
操作修飾符:
--check-device 當創建增量歸檔時檢查設備號(默認)
-g, --listed-incremental=FILE 處理新式的 GNU 格式的增量備份
-G, --incremental 處理老式的 GNU 格式的增量備份
--ignore-failed-read
當遇上不可讀文件時不要以非零值退出
--level=NUMBER 所創建的增量列表歸檔的輸出級別
-n, --seek 歸檔可檢索
--no-check-device 當創建增量歸檔時不要檢查設備號
--no-seek 歸檔不可檢索
--occurrence[=NUMBER] 僅處理歸檔中每個文件的第 NUMBER
個事件;僅當與以下子命令 --delete,
--diff, --extract 或是 --list
中的一個聯合使用時,此選項才有效。而且不管文件列表是以命令行形式給出或是通過
-T 選項指定的;NUMBER 值默認為 1
--sparse-version=MAJOR[.MINOR]
設置所用的離散格式版本(隱含
--sparse)
-S, --sparse 高效處理離散文件
重寫控制:
-k, --keep-old-files don't replace existing files when extracting,
treat them as errors
--keep-directory-symlink preserve existing symlinks to directories when
extracting
--keep-newer-files
不要替換比歸檔中副本更新的已存在的文件
--no-overwrite-dir 保留已存在目錄的元數據
--one-top-level[=DIR] create a subdirectory to avoid having loose files
extracted
--overwrite 解壓時重寫存在的文件
--overwrite-dir 解壓時重寫已存在目錄的元數據(默認)
--recursive-unlink 解壓目錄之前先清除目錄層次
--remove-files 在添加文件至歸檔後刪除它們
--skip-old-files don't replace existing files when extracting,
silently skip over them
-U, --unlink-first 在解壓要重寫的文件之前先刪除它們
-W, --verify 在寫入以後嘗試校驗歸檔
選擇輸出流:
--ignore-command-error 忽略子進程的退出代碼
--no-ignore-command-error
將子進程的非零退出代碼認為發生錯誤
-O, --to-stdout 解壓文件至標准輸出
--to-command=COMMAND
將解壓的文件通過管道傳送至另一個程序
操作文件屬性:
--atime-preserve[=METHOD]
在輸出的文件上保留訪問時間,要麼通過在讀取(默認
METHOD=『replace』)後還原時間,要不就不要在第一次(METHOD=『system』)設置時間
--clamp-mtime only set time when the file is more recent than
what was given with --mtime
--delay-directory-restore
直到解壓結束才設置修改時間和所解目錄的許可權
--group=名稱 強制將 NAME
作為所添加的文件的組所有者
--mode=CHANGES 強制將所添加的文件(符號)更改為許可權
CHANGES
--mtime=DATE-OR-FILE 從 DATE-OR-FILE 中為添加的文件設置
mtime
-m, --touch 不要解壓文件的修改時間
--no-delay-directory-restore
取消 --delay-directory-restore 選項的效果
--no-same-owner
將文件解壓為您所有(普通用戶默認此項)
--no-same-permissions
從歸檔中解壓許可權時使用用戶的掩碼位(默認為普通用戶服務)
--numeric-owner 總是以數字代表用戶/組的名稱
--owner=名稱 強制將 NAME
作為所添加的文件的所有者
-p, --preserve-permissions, --same-permissions
解壓文件許可權信息(默認只為超級用戶服務)
--preserve 與 -p 和 -s 一樣
--same-owner
嘗試解壓時保持所有者關系一致(超級用戶默認此項)
-s, --preserve-order, --same-order
member arguments are listed in the same order as
the files in the archive
--sort=ORDER directory sorting order: none (default), name or
inode
Handling of extended file attributes:
--acls Enable the POSIX ACLs support
--no-acls Disable the POSIX ACLs support
--no-selinux Disable the SELinux context support
--no-xattrs Disable extended attributes support
--selinux Enable the SELinux context support
--xattrs Enable extended attributes support
--xattrs-exclude=MASK specify the exclude pattern for xattr keys
--xattrs-include=MASK specify the include pattern for xattr keys
設備選擇和切換:
-f, --file=ARCHIVE 使用歸檔文件或 ARCHIVE 設備
--force-local
即使歸檔文件存在副本還是把它認為是本地歸檔
-F, --info-script=名稱, --new-volume-script=名稱
在每卷磁帶最後運行腳本(隱含 -M)
-L, --tape-length=NUMBER 寫入 NUMBER × 1024 位元組後更換磁帶
-M, --multi-volume 創建/列出/解壓多卷歸檔文件
--rmt-command=COMMAND 使用指定的 rmt COMMAND 代替 rmt
--rsh-command=COMMAND 使用遠程 COMMAND 代替 rsh
--volno-file=FILE 使用/更新 FILE 中的卷數
設備分塊:
-b, --blocking-factor=BLOCKS 每個記錄 BLOCKS x 512 位元組
-B, --read-full-records 讀取時重新分塊(只對 4.2BSD 管道有效)
-i, --ignore-zeros 忽略歸檔中的零位元組塊(即文件結尾)
--record-size=NUMBER 每個記錄的位元組數 NUMBER,乘以 512
選擇歸檔格式:
-H, --format=FORMAT 創建指定格式的歸檔
FORMAT 是以下格式中的一種:
gnu GNU tar 1.13.x 格式
oldgnu GNU 格式 as per tar <= 1.12
pax POSIX 1003.1-2001 (pax) 格式
posix 等同於 pax
ustar POSIX 1003.1-1988 (ustar) 格式
v7 old V7 tar 格式
--old-archive, --portability
等同於 --format=v7
--pax-option=關鍵字[[:]=值][,關鍵字[[:]=值]]...
控制 pax 關鍵字
--posix 等同於 --format=posix
-V, --label=TEXT 創建帶有卷名 TEXT
的歸檔;在列出/解壓時,使用 TEXT
作為卷名的模式串
壓縮選項:
-a, --auto-compress 使用歸檔後綴名來決定壓縮程序
-I, --use-compress-program=PROG
通過 PROG 過濾(必須是能接受 -d
選項的程序)
-j, --bzip2 通過 bzip2 過濾歸檔
-J, --xz 通過 xz 過濾歸檔
--lzip 通過 lzip 過濾歸檔
--lzma 通過 xz 過濾歸檔
--lzop 通過 xz 過濾歸檔
--no-auto-compress 不使用歸檔後綴名來決定壓縮程序
-z, --gzip, --gunzip, --ungzip 通過 gzip 過濾歸檔
-Z, --compress, --uncompress 通過 compress 過濾歸檔
本地文件選擇:
--add-file=FILE 添加指定的 FILE 至歸檔(如果名字以 -
開始會很有用的)
--backup[=CONTROL] 在刪除前備份,選擇 CONTROL 版本
-C, --directory=DIR 改變至目錄 DIR
--exclude=PATTERN 排除以 PATTERN 指定的文件
--exclude-backups 排除備份和鎖文件
--exclude-caches 除標識文件本身外,排除包含
CACHEDIR.TAG 的目錄中的內容
--exclude-caches-all 排除包含 CACHEDIR.TAG 的目錄
--exclude-caches-under 排除包含 CACHEDIR.TAG
的目錄中所有內容
--exclude-ignore=FILE read exclude patterns for each directory from
FILE, if it exists
--exclude-ignore-recursive=FILE
read exclude patterns for each directory and its
subdirectories from FILE, if it exists
--exclude-tag=FILE 除 FILE 自身外,排除包含 FILE
的目錄中的內容
--exclude-tag-all=FILE 排除包含 FILE 的目錄
--exclude-tag-under=FILE 排除包含 FILE 的目錄中的所有內容
--exclude-vcs 排除版本控制系統目錄
--exclude-vcs-ignores read exclude patterns from the VCS ignore files
-h, --dereference
跟蹤符號鏈接;將它們所指向的文件歸檔並輸出
--hard-dereference
跟蹤硬鏈接;將它們所指向的文件歸檔並輸出
-K, --starting-file=MEMBER-NAME
begin at member MEMBER-NAME when reading the
archive
--newer-mtime=DATE 當只有數據改變時比較數據和時間
--no-null 禁用上一次的效果 --null 選項
--no-recursion 避免目錄中的自動降級
--no-unquote do not unquote input file or member names
--null -T 讀取以空終止的名字,-C 禁用
-N, --newer=DATE-OR-FILE, --after-date=DATE-OR-FILE
只保存比 DATE-OR-FILE 更新的文件
--one-file-system 創建歸檔時保存在本地文件系統中
-P, --absolute-names don't strip leading '/'s from file names
--recursion 目錄遞歸(默認)
--suffix=STRING 在刪除前備份,除非被環境變數
SIMPLE_BACKUP_SUFFIX
覆蓋,否則覆蓋常用後綴(『』)
-T, --files-from=FILE 從 FILE
中獲取文件名來解壓或創建文件
--unquote unquote input file or member names (default)
-X, --exclude-from=FILE 排除 FILE 中列出的模式串
文件名變換:
--strip-components=NUMBER 解壓時從文件名中清除 NUMBER
個引導部分
--transform=EXPRESSION, --xform=EXPRESSION
使用 sed 代替 EXPRESSION
來進行文件名變換
文件名匹配選項(同時影響排除和包括模式串):
--anchored 模式串匹配文件名頭部
--ignore-case 忽略大小寫
--no-anchored patterns match after any '/' (default for
exclusion)
--no-ignore-case 匹配大小寫(默認)
--no-wildcards 逐字匹配字元串
--no-wildcards-match-slash wildcards do not match '/'
--wildcards 使用通配符(默認對 exclusion )
--wildcards-match-slash wildcards match '/' (default for exclusion)
提示性輸出:
--checkpoint[=NUMBER] 每隔 NUMBER
個記錄顯示進度信息(默認為 10 個)
--checkpoint-action=ACTION 在每個檢查點上執行 ACTION
--full-time 按文件原本時間格式列印
--index-file=FILE 將詳細輸出發送至 FILE
-l, --check-links
只要不是所有鏈接都被輸出就列印信息
--no-quote-chars=STRING 禁用來自 STRING 的字元引用
--quote-chars=STRING 來自 STRING 的額外的引用字元
--quoting-style=STYLE 設置名稱引用風格;有效的 STYLE
值請參閱以下說明
-R, --block-number 每個信息都顯示歸檔內的塊數
--show-defaults 顯示 tar 默認選項
--show-omitted-dirs
列表或解壓時,列出每個不匹配查找標準的目錄
--show-snapshot-field-ranges
show valid ranges for snapshot-file fields
--show-transformed-names, --show-stored-names
顯示變換後的文件名或歸檔名
--totals[=SIGNAL] 處理歸檔後列印出總位元組數;當此
SIGNAL 被觸發時帶參數 -
列印總位元組數;允許的信號為:
SIGHUP,SIGQUIT,SIGINT,SIGUSR1 和
SIGUSR2;同時也接受不帶 SIG
前綴的信號名稱
--utc 以 UTC 格式列印文件修改時間
-v, --verbose 詳細地列出處理的文件
--warning=KEYWORD 警告控制:
-w, --interactive, --confirmation
每次操作都要求確認
兼容性選項:
-o 創建歸檔時,相當於
--old-archive;展開歸檔時,相當於
--no-same-owner
其它選項:
-?, --help 顯示此幫助列表
--restrict 禁用某些潛在的有危險的選項
--usage 顯示簡短的用法說明
--version 列印程序版本
長選項和相應短選項具有相同的強制參數或可選參數。
The backup suffix is '~', unless set with --suffix or SIMPLE_BACKUP_SUFFIX.
The version control may be set with --backup or VERSION_CONTROL, values are:
none, off never make backups
t, numbered make numbered backups
nil, existing numbered if numbered backups exist, simple otherwise
never, simple always make simple backups
--quoting-style 選項的有效參數為:
literal
shell
shell-always
c
c-maybe
escape
locale
clocale
此 tar 默認為:
--format=gnu -f- -b20 --quoting-style=escape --rmt-command=/usr/lib/tar/rmt
--rsh-command=/usr/bin/rsh
8. SHELL腳本,解壓縮指定目錄下的ZIP文件到另一個目錄下
#!/bin/bash
foriin$(ls/opt/bin/*.zip2>/dev/null)
do
unzip$i-d/opt/wep
done
9. shell腳本壓縮文件
#!/bin/bash
##for file zip and unzip
#date:2011/7/20
#input:current_filename
#use gunzip\bzip\tar commands to do this .
#two choices:pack||unpack
pack()
{
##use tar cmd to pack file
echo "Now will use tar to pack the file......"
echo "tar $CUR_FILE ......."
#sleep 1
tar -zcvf $CUR_FILE.tar.gz $CUR_FILE
if [ "$?" -eq "0" ];then
echo "pack file $CUR_FILE into tar.gz file ok~!"
else
echo "Error:Pack file into tar.gz failed~!"
exit 1
fi
}
unpack(){
##get file type
ftype=`file $CUR_FILE`
#echo file type
echo "Your file type is:###$ftype"
case "$ftype" in
"$CUR_FILE: Zip archive"*)
unzip $CUR_FILE
echo "unzip $CUR_FILE OK~!"
;;
"$CUR_FILE: gzip compressed"*)
gunzip $CUR_FILE
echo "gunzip $CUR_FILE OK~!"
;;
"$CUR_FILE: bzip2 compressed"*)
bunzip2 $CUR_FILE
echo "bunzip $CUR_FILE OK~!"
;;
*)
echo "File $CUR_FILE can not be uncompressed!!!"
exit 1
;;
esac
}
CUR_FILE="$1"
if [ -z $CUR_FILE];then
echo "Please input your filename!"
exit 1
else
echo "Your file name:$CUR_FILE"
##make target choice
echo "Which work you wanna do?"
select var in "pack" "unpack";do
break
done
echo "You selected $var file....."
case $var in
pack)
pack CUR_FILE
;;
unpack)
unpack CUR_FILE
;;
*)
echo "Usage:select option error!"
exit 1
esac
fi
10. linux shell批量解壓腳本
全部解壓?7za 格式必須有他專用的解壓程序 7z。文件名不要包含空格。
for i in *.7za
do
mkdir -p "x/$i"
7z x "$i" -o"x/$i"
done
7z解壓自動使用多cpu核心。4個解壓文件一個一個解壓比4個同時解壓效率高。