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

[文本处理] [已解决]批处理怎样删除/去掉txt文本每行最后一个字符?

本帖最后由 pcl_test 于 2017-6-7 08:10 编辑

如题:
a.txt内容
aaa-
aaa-bbb-

处理结果
b.txt
aaa
aaa-bbb

[ 本帖最后由 daohe 于 2010-4-5 22:37 编辑 ]
1

评分人数

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

  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for /f "delims=" %%i in (a.txt) do (
  4. set str=%%i
  5. set str=!str~0,-1!
  6. call echo %%str%% >>b.txt
  7. )
复制代码

TOP

请问tokens=delims 是什么意思哇

TOP

书写错误,没啥意思
嘿嘿

TOP

  1. sed "s/.$//" a.txt >b.txt
复制代码

TOP

回复 2楼 的帖子

2楼测试结果

b.txt
ECHO 处于关闭状态。
ECHO 处于关闭状态。

TOP

回复 5楼 的帖子

5楼测试结果

功能实现

b,txt首行出现
Invalid keyboard code specified

TOP

原帖由 daohe 于 2010-4-5 15:37 发表
2楼测试结果

b.txt
ECHO 处于关闭状态。
ECHO 处于关闭状态。

2楼的代码少打了个冒号

在文本中不含敏感字符的情况下,可以:
  1. @echo off
  2. for /f "delims=" %%i in (a.txt) do set s=%%i&>>b.txt call echo %%s:~0,-1%%
复制代码
1

评分人数

TOP

  1. sed -i "s/.$//" a.txt
复制代码

TOP

返回列表