<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0">
<channel>
<title><![CDATA[向东博客 专注WEB应用 构架之美 --- 构架之美，在于尽态极妍 | 应用之美，在于药到病除]]></title> 
<link>http://jackxiang.com/index.php</link> 
<description><![CDATA[赢在IT，Playin' with IT,Focus on Killer Application,Marketing Meets Technology.]]></description> 
<language>zh-cn</language> 
<copyright><![CDATA[向东博客 专注WEB应用 构架之美 --- 构架之美，在于尽态极妍 | 应用之美，在于药到病除]]></copyright>
<item>
<link>http://jackxiang.com/post//</link>
<title><![CDATA[[实践OK]用shell实现带日期的文件名备份及文件名后缀及文件名，shell 去掉文件名后缀的简单方法及shell调试的常用参数，提取文件名。]]></title> 
<author>jack &lt;xdy108@126.com&gt;</author>
<category><![CDATA[Php/Js/Shell/Go]]></category>
<pubDate>Thu, 26 Jul 2012 07:52:22 +0000</pubDate> 
<guid>http://jackxiang.com/post//</guid> 
<description>
<![CDATA[ 
	echo -n `date +%Y%m%d%H%M%S`&#124; pbcopy<br/>20220805095854<br/><br/>shell如下：<br/>cat /data/www/up.jackxiang.com/bak.sh<br/><textarea name="code" class="php" rows="15" cols="100">
#!/bin/sh
OLD_IFS=$IFS #保存原始值
IFS=$&#039;&#92;n&#039;&nbsp;&nbsp;&nbsp;&nbsp;#改变IFS的值
path=&quot;/data/www/up.jackxiang.com/tmp&quot;
chdir $path
for i in `ls -1 ./`;do chmod a-x ./$i;done
for i in `find ./ -type f -mmin +3`;do mkdir -p ../bak/`date +%Y%m%d`;i=$&#123;i/&#92;.&#92;//&#125;;mv $i ../bak/`date +%Y%m%d`/`date +%Y%m%d`.$&#123;i%.*&#125;.`date +%H%M`.$&#123;i##*.&#125;;done
for i in `ls -1 ./bak/`;do chmod a-x ./bak/$i;done
find $path/../bak -mtime +30 -exec rm -rf &#123;&#125; &#92;;
IFS=$OLD_IFS #还原IFS的原始值

From:<a href="https://jackxiang.com/post/10785/" target="_blank">https://jackxiang.com/post/10785/</a>
</textarea><br/>为何要这么干的需求来源@[实践OK]CentOS下sendfile直接下载文件结合PHP的配置，curl -T 上传后下载高效实现方法。<br/>：<a href="https://jackxiang.com/post/10785/" target="_blank">https://jackxiang.com/post/10785/</a><br/><br/><br/>1206分论坛三预排座次表?打印80份?.pdf<br/><textarea name="code" class="php" rows="15" cols="100">
文件名去掉后缀：echo $&#123;i%.*&#125;;
for i in `ls -1 ./tmp/`;do echo $&#123;i%.*&#125;;done
1206分论坛三预排座次表（打印80份）

获取到文件名的后缀名：
#for i in `ls -1 ./tmp/`;do echo $&#123;i##*.&#125;;done
pdf

</textarea><br/><br/><br/><br/>在文件后缀前加上一个日期：<br/><textarea name="code" class="php" rows="15" cols="100">
#for i in `ls -1 .`;do echo $&#123;i%.*&#125;.`date +%Y%m%d`.$&#123;i%.*&#125;;done
1206分论坛三预排座次表（打印80份）.20201210.1206分论坛三预排座次表（打印80份）
id_rsa.20201210.id_rsa
</textarea><br/><br/><textarea name="code" class="php" rows="15" cols="100">
#echo basename &quot;$filename&quot;&nbsp;&nbsp;&nbsp;&nbsp;
basename tmp/abdfd.pdf

[root@jackxiang_owncloud_tools_diff_nginx_php_mysql_redis_47_94_88_237:/data/www/up.jackxiang.com]
#echo extension=&quot;$&#123;filename##*.&#125;&quot;
extension=pdf

[root@jackxiang_owncloud_tools_diff_nginx_php_mysql_redis_47_94_88_237:/data/www/up.jackxiang.com]
#filename=&quot;$&#123;filename%.*&#125;&quot;

[root@jackxiang_owncloud_tools_diff_nginx_php_mysql_redis_47_94_88_237:/data/www/up.jackxiang.com]
#echo filename
filename

[root@jackxiang_owncloud_tools_diff_nginx_php_mysql_redis_47_94_88_237:/data/www/up.jackxiang.com]
#echo $filename
tmp/abdfd

</textarea><br/><br/>1）shell 去掉文件名后缀的简单方法：<br/><textarea name="code" class="php" rows="15" cols="100">
filename=&quot;a.txt.bat&quot;
echo $&#123;filename%.*&#125;
a.txt
</textarea><br/>2）shell调试的常用参数：<br/><textarea name="code" class="php" rows="15" cols="100">sh -x shellscript.sh</textarea><br/><br/><br/>提取文件名：<br/>$&#123;var##*/&#125;<br/><br/><br/>echo $rpm<br/>/root/rpmbuild/RPMS/x86_64/xlswriter-php73-1.3.6-200925115211.el7.centos.x86_64.rpm<br/>echo $&#123;rpm##*/&#125;<br/>xlswriter-php73-1.3.6-200925115211.el7.centos.x86_64.rpm<br/><br/>提取文件后缀：<br/>echo $&#123;rpm##*.&#125;<br/>rpm<br/><br/>提取文件的多个后缀：<br/>echo $&#123;rpm#*.&#125;<br/>3.6-200925115211.el7.centos.x86_64.rpm<br/><br/>提取文件所在目录：<br/>echo $&#123;rpm%/*&#125;<br/>/root/rpmbuild/RPMS/x86_64<br/><br/>右边算起的最后一个&#039;.&#039;字符及其右边的内容<br/>echo $&#123;rpm%%.*&#125;<br/>/root/rpmbuild/RPMS/x86_64/xlswriter-php73-1<br/><br/><br/><br/>$&#123;&#125;总结<br/><br/>其实$&#123;&#125;并不是专门为提取文件名或目录名的，它的使用是变量的提取和替换等等操作，它可以提取非常多的内容，并不一定是上面五个例子中的&#039;/&#039;或&#039;.&#039;。也就是说，上面的使用方法只是它使用的一个特例。<br/><br/>看到上面的这些命令，可能会让人感到非常难以理解和记忆，其实不然，它们都是有规律的。<br/><br/>#：表示从左边算起第一个<br/><br/>%：表示从右边算起第一个<br/><br/>##：表示从左边算起最后一个<br/><br/>%%：表示从右边算起最后一个<br/><br/>换句话来说，＃总是表示左边算起，％总是表示右边算起。<br/><br/>＊：表示要删除的内容，对于#和##的情况，它位于指定的字符（例子中的&#039;/&#039;和&#039;.&#039;）的左边，表于删除指定字符及其左边的内容；对于%和%%的情况，它位于指定的字符（例子中的&#039;/&#039;和&#039;.&#039;）的右边，表示删除指定字符及其右边的内容。这里的&#039;*&#039;的位置不能互换，即不能把*号放在#或##的右边，反之亦然。<br/><br/>例如：$&#123;var%%x*&#125;表示找出从右边算起最后一个字符x，并删除字符x及其右边的字符。<br/><br/>看到这里，就可以知道，其实该命令的用途非常广泛，上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。<br/><br/><br/><br/>更多摘录：<br/><br/>转自：https://blog.csdn.net/ljianhui/article/details/43128465<br/><br/>很多时候在使用Linux的shell时，我们都需要对文件名或目录名进行处理，通常的操作是由路径中提取出文件名，从路径中提取出目录名，提取文件后缀名等等。例如，从路径/dir1/dir2/file.txt中提取也文件名file.txt，提取出目录/dir1/dir2，提取出文件后缀txt等。<br/><br/>下面介绍两种常用的方法来进行相关的操作。<br/><br/>一、使用$&#123;&#125;<br/><br/>1、$&#123;var##*/&#125;<br/>该命令的作用是去掉变量var从左边算起的最后一个&#039;/&#039;字符及其左边的内容，返回从左边算起的最后一个&#039;/&#039;（不含该字符）的右边的内容。使用例子及结果如下：<br/><br/><br/><br/>从运行结果可以看到，使用该命令，可以提取出我们需要的文件名file.txt。<br/><br/>若使用时在shell程序文件中，可以使用变量来保存这个结果，再加以利用，如file=$&#123;var##*/&#125;<br/><br/>2、$&#123;var##*.&#125;<br/><br/>该命令的作用是去掉变量var从左边算起的最后一个&#039;.&#039;字符及其左边的内容，返回从左边算起的最后一个&#039;.&#039;（不含该字符）的右边的内容。使用例子及结果如下：<br/><br/><br/><br/>从运行结果可以看到，使用该命令，可以提取出我们需要的文件后缀。<br/><br/>如果文件的后缀不仅有一个，例如，file.tar.gz，命令$&#123;var##*.&#125;仅能提取最后一个后缀，而我想提取tar.gz时该怎么办？那么就要用下面所说的$&#123;var#*.&#125;命令了。<br/><br/>3、$&#123;var#*.&#125;<br/><br/>该命令的作用是去掉变量var从左边算起的第一个&#039;.&#039;字符及其左边的内容，返回从左边算起第一个&#039;.&#039;（不含该字符）的右边部分的内容。使用例子及结果如下：<br/><br/><br/><br/>从运行结果可以看到，使用该命令，可以提取出文件的多个后缀。<br/><br/>4、$&#123;var%/*&#125;<br/><br/>该命令的使用是去掉变量var从右边算起的第一个&#039;/&#039;字符及其右边的内容，返回从右边算起的第一个&#039;/&#039;（不含该字符）的左边的内容。使用例子及结果如下：<br/><br/><br/><br/>从运行的结果可以看到，使用该命令，可以提取出我们需要的文件所在的目录<br/><br/>5、$&#123;var%%.*&#125;<br/><br/>该命令的使用是去掉变量var从右边算起的最后一个&#039;.&#039;字符及其右边的内容，返回从右边算起的最后一个&#039;.&#039;（不含该字符）的左边的内容。使用例子及结果如下：<br/><br/><br/><br/>当我们需要建立一个与文件名相同名字（没有后缀）的目录与对应的文件相对应时，就可以使用该命令来进行操作。例如，解压文件的情况就与此类似，我们压缩文件file.zip时，会在与file.zip同级目录下建立一个名为file的目录。<br/><br/>6、$&#123;&#125;总结<br/><br/>其实$&#123;&#125;并不是专门为提取文件名或目录名的，它的使用是变量的提取和替换等等操作，它可以提取非常多的内容，并不一定是上面五个例子中的&#039;/&#039;或&#039;.&#039;。也就是说，上面的使用方法只是它使用的一个特例。<br/><br/>看到上面的这些命令，可能会让人感到非常难以理解和记忆，其实不然，它们都是有规律的。<br/><br/>#：表示从左边算起第一个<br/><br/>%：表示从右边算起第一个<br/><br/>##：表示从左边算起最后一个<br/><br/>%%：表示从右边算起最后一个<br/><br/>换句话来说，＃总是表示左边算起，％总是表示右边算起。<br/><br/>＊：表示要删除的内容，对于#和##的情况，它位于指定的字符（例子中的&#039;/&#039;和&#039;.&#039;）的左边，表于删除指定字符及其左边的内容；对于%和%%的情况，它位于指定的字符（例子中的&#039;/&#039;和&#039;.&#039;）的右边，表示删除指定字符及其右边的内容。这里的&#039;*&#039;的位置不能互换，即不能把*号放在#或##的右边，反之亦然。<br/><br/>例如：$&#123;var%%x*&#125;表示找出从右边算起最后一个字符x，并删除字符x及其右边的字符。<br/><br/>看到这里，就可以知道，其实该命令的用途非常广泛，上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。<br/><br/>二、basename和dirname<br/><br/>$&#123;&#125;并不是专门为提取文件名和目录名设计的命令，那么basename和dirname命令就是专门为做这一件事而已准备的了。<br/><br/>1、basename<br/><br/>该命令的作用是从路径中提取出文件名，使用方法为basename NAME [SUFFIX]。<br/><br/>1）从路径中提出出文件名（带后缀），例子如下：<br/><br/><br/><br/>2）从上面命令的用法中可以看到，后缀（SUFFIX）是一个可选项。所以，若只想提取出文件名file，而不带有后缀，还可以在变量的后面加上后缀名，例子如下：<br/><br/><br/><br/>2、dirname<br/><br/>该命令的作用是从路径中提取出目录名，使用方法为 dirname NAME<br/><br/>使用例子如下：<br/><br/><br/><br/>这样就提取出了file.txt文件所在的目录。<br/><br/>注：该命令不仅能提取出普通文件所的目录，它能提取出任何文件所在的目录，例如目录所在的目录，如下：<br/><br/><br/><br/>它提取出了目录dir2所在的目录dir1.
]]>
</description>
</item><item>
<link>http://jackxiang.com/post//#blogcomment</link>
<title><![CDATA[[评论] [实践OK]用shell实现带日期的文件名备份及文件名后缀及文件名，shell 去掉文件名后缀的简单方法及shell调试的常用参数，提取文件名。]]></title> 
<author> &lt;user@domain.com&gt;</author>
<category><![CDATA[评论]]></category>
<pubDate>Thu, 01 Jan 1970 00:00:00 +0000</pubDate> 
<guid>http://jackxiang.com/post//#blogcomment</guid> 
<description>
<![CDATA[ 
	
]]>
</description>
</item>
</channel>
</rss>