首页脚本把首行和尾行互换的批处理

把首行和尾行互换的批处理

时间2024-02-12 06:00:03发布访客分类脚本浏览273
导读:收集整理的这篇文章主要介绍了把首行和尾行互换的批处理,觉得挺不错的,现在分享给大家,也给大家做个参考。 然后在新文本的首行写入提取到的最后一行,用 findstr 语句过滤掉原文本的第一...
收集整理的这篇文章主要介绍了把首行和尾行互换的批处理,觉得挺不错的,现在分享给大家,也给大家做个参考。 然后在新文本的首行写入提取到的最后一行,用 findstr 语句过滤掉原文本的第一行和最后一行,在最后一行 之后添加提取到的第一行。
复制代码 代码如下:
@echo off
:: 目的:把首行和尾行互换
:: 思路:
:: 提取第一行和最后一行内容(若首行和最后一行是空行,则提取到的是非空的第一行和非空的最后一行内容),
:: 然后在新文本的首行写入提取到的最后一行,用 findstr 语句过滤掉原文本的第一行和最后一行,在最后一行
:: 之后添加提取到的第一行。
:: 因为 findstr 处理最后一行有条件限制,所以先在最后一行之后生成一个空行,以保证提取的准确性
:: 注意:请保证test.txt中没有敏感字符,没有内容重复的行,并且首行不能为空
::    
::     
copy test.txt test.bak> nul
echo.> > test.txt
set num=0
setlocal enabledelayedexpansion
for /f "delims=" %%i in (test.txt) do (
set str=%%i
set /a num+=1
if !num! equ 1 set VAR=%%i
)
> test_.txt echo.%str%
findstr /b /e /v /c:"%str%" /c:"%var%" test.txt> > test_.txt
> > test_.txt echo.%var%
move test.bak test.txt
start test_.txt
goto :eof

@echo off
:: 可以处理首行为空、行内容重复的情况,
:: 注意:因为 findstr /n 统计行数的时候,会忽略最后一个空行
:: 所以,若在最后有空行的话,请保证空行的个数大于1
findstr /n .* test.txt> tmp1.txt
for /f "tokens=1* delims=:" %%i in (tmp1.txt) do (
if %%i equ 1 set str=%%j
set line=%%i& set var=%%j
)
> tmp2.txt echo %line%:%var%
findstr /b /v /c:"1:" /c:"%line%:" tmp1.txt> > tmp2.txt
echo 1:%str%> > tmp2.txt
echo.> > tmp2.txt
cd.> result.txt
for /f "tokens=1* delims=:" %%i in (tmp2.txt) do > > result.txt echo.%%j
del /q tmp1.txt tmp2.txt
start result.txt

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: 把首行和尾行互换的批处理
本文地址: https://pptw.com/jishu/610851.html
把两个文件中的不同之处提取到某个文件中去 拼接相临的奇偶行文本内容

游客 回复需填写必要信息