[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文本处理] 【已解决】如何用批处理删除文本中指定行最后一个指定字符?

本帖最后由 Cyccllee 于 2015-2-7 17:03 编辑

现文本中内容如下:
.1
XI L=1U T=1s
XI L=4U M=1
XI L=3U T=3s
XI L=7U M=3
.1s
.2
XI L=2U T=2s
XI L=3U M=1
XI L=3U T=8s
XI L=3U M=5
.2s

要将指定行: 是除去开头字母为.的其他行。
删除内容:指定行中最后一个字母如果是s,就删除s,不是替换成空格。

需要的文本内容如下:
.1
XI L=1U T=1
XI L=4U M=1
XI L=3U T=3
XI L=7U M=3
.1s
.2
XI L=2U T=2
XI L=3U M=1
XI L=3U T=8
XI L=3U M=5
.2s

求大神帮忙!!
1

评分人数

    • Batcher: 感谢给帖子标题标注[已解决]字样PB + 2

gawk "{print gensub(/^([^.].*)s$/,\"\\1\",1);}" 1.txt

sed -i.txt "s/^\([^.].*\)s$/\1/" 1.txt

TOP

回复 2# pcl_test
谢谢,你的回答完美解决了我的问题~

TOP

sed "/^\./d;s/s$//g" a.txt

TOP

本帖最后由 pcl_test 于 2015-2-7 15:51 编辑

回复 1# Cyccllee
假设有test.txt
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for /f "delims=" %%i in ('type "test.txt"') do (
  4. set "str=%%i"
  5. if "!str:~0,1!" equ "." (
  6. echo !str!>>$
  7. ) else (
  8. if "!str:~-1!" equ "s" (
  9. echo !str:~0,-1!>>$
  10. ) else (
  11. echo !str!>>$
  12. )
  13. )
  14. )
  15. del "test.txt" /f /q
  16. ren $ "test.txt"
  17. pause
复制代码
1

评分人数

TOP

返回列表