zoukankan      html  css  js  c++  java
  • linux批量解压缩

    1. find . -name "stat_*_2012_05_26_log.tgz" -exec cp {} /home/adstat/apache_log/stat/ \;  

     上述命令代表在当前文件夹下查找符合正则表达式stat_*_2012_05_26_log.tgz 的文件并分别复制到/home/adstat/apache_log/stat/目录下。 

      那么批量解压文件是否这样呢:

    Java代码  收藏代码
    1. find . -name "stat_*_2012_05_26_log.tgz"|xargs tar -zxvf  

      其实是不可以的,执行结果如下:

    Java代码  收藏代码
    1. tar: ./stat_64_138_2012_05_26_log.tgz:归档中找不到  
    2. tar: ./stat_10_10_75_80_2012_05_26_log.tgz:归档中找不到  
    3. tar: ./stat_64_139_2012_05_26_log.tgz:归档中找不到  
    4. tar: ./stat_74_195_2012_05_26_log.tgz:归档中找不到  

      为什么tar不支持这种通配符语法呢?

    通配符是shell解决的问题
    tar -xvf *.tar
    实际上执行tar时,tar接收到的是
    tar -xvf a.tar b.tar c.tar ...
    如果当前目录跟本没有tar的东西,那么tar就收到'*.tar'这个参数
    与win不同,linux所有字符都可以作文件名,也即目录中不存在着 *.tar这个文件
    为了防止 *.tar被shell解释为a.tar b.tar c.tar...
    可以给它加个单引号
     
    用tar解开一个Archive时,语法是
    tar -xvf <tarfile.tar> <archived_file>
    <tarfile.tar> 是选项f所要求的,只能是一个文件,比如myfiles.tar。
    <archived_file> 是myfiles.tar所包含的归了档的文件中的一个或者多个成员文件。如果是多个,可以用通配符。
    先别跟我急,我知道,这些你是清楚的。但是,你的问题是,用了
    tar -xvf *.tar
    如楼上所说,tar接收到的是
    tar -xvf a.tar b.tar c.tar ...
    tar把你的意图理解为,在a.tar里解出b.tar c.tar .
     
    可以使用的方法如下:
    方法:
    第一:
    for tar in *.tar.gz;  do tar xvf $tar; done
    for tar in *.tar.bz2; do tar xvf $tar; done
     
    第二:用tar命令批量解压某个文件夹下所有的tar.gz文件
    ls *.tar.gz | xargs -n1 tar xzvf
     
    第三:find -maxdepth 1 -name "*.gz"|xargs -i tar xvzf {}
    这条命令可解压当前目录下的所有gz文件
    批量解压是比较郁闷的事,以前尝试各种方法,甚至用脚本循环语句解压都不行
    现在发现这条命令可以搞定,maxdepth表示搜索深度,1代表只搜索当前目录
     
    第四:for i in $(ls *.gz);do tar xvf $i;done
  • 相关阅读:
    SpringBootMybatis 关于Mybatis-generator-gui的使用|数据库的编码注意点|各项复制模板
    SpringBootMVC04——Mybatis
    SpringBootMVC02——SpringDataJpa与ThymeLeaf
    Big Data(六)用户权限实操&HDFS-API实操
    Big Data(五)关于Hadoop的HA的实践搭建
    Big Data(四)关于Hadoop的HA&CAP理论详解
    Big Data(三)伪分布式和完全分布式的搭建
    SpringBootMVC02——Spring Data JPA的使用&JSP的使用
    SpringBootMVC01——A simple SpringBootMVC Sample
    yum安装mysql
  • 原文地址:https://www.cnblogs.com/lansor/p/2574214.html
Copyright © 2011-2022 走看看