找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 26129|回复: 3

[文本处理] 【已解决】BAT:如何这样批量处理文本数据

[复制链接]
发表于 2015-2-11 21:37:23 | 显示全部楼层 |阅读模式
本帖最后由 思想之翼 于 2015-2-11 22:31 编辑

D:/数据/内有若干txt文本,每个文本内的数据格式如下:
观测地点:33  重量:0
观测地点:31  重量:1
观测地点:31  重量:6
观测地点:30  重量:2
观测地点:29  重量:9
观测地点:28  重量:5
观测地点:28  重量:7
观测地点:26  重量:3
观测地点:24  重量:4
观测地点:20  重量:8
0162957348

现在欲将每个文本做如下处理:
1、只保留第11行数据:0162957348
2、在保留下的数据首位前添加英文逗号:'0162957348
3、在保留下的数据末位后添加回车键
4、数据处理后覆盖原文本的数据

这样的代码如何写?恳望得到帮助。

评分

参与人数 1PB +2 收起 理由
Batcher + 2 感谢给帖子标题标注[已解决]字样

查看全部评分

发表于 2015-2-11 21:53:31 | 显示全部楼层
本帖最后由 pcl_test 于 2015-2-11 22:31 编辑

回复 1# 思想之翼

测试前先备份原文件
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. cd /d "D:\数据"
  4. for /f "delims=" %%a in ('dir /b *.txt') do (
  5. set n=1
  6. for /f "delims=" %%b in ('type "%%~nxa"') do (
  7. if "!n!" == "11" (
  8. >$ echo,'%%b
  9. ) else (
  10. set /a n+=1
  11. )
  12. )
  13. move $ "%%~nxa"
  14. )
  15. pause
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢

查看全部评分

发表于 2015-2-11 22:17:25 | 显示全部楼层
本帖最后由 tmplinshi 于 2015-2-11 22:20 编辑
  1. @echo off
  2. pushd "d:\数据"
  3. for /f "delims=" %%f in ('dir /b *.txt') do (
  4.         call :FileReadLine "%%f" 11 ' > .temp_file
  5.         move .temp_file "%%f"
  6. )
  7. exit /b

  8. :FileReadLine <Filename> <LineNum> [Prefix]
  9.         set /a skip=%2-1
  10.         for /f "usebackq skip=%skip% tokens=*" %%i in ("%~1") do (
  11.                 echo,%3%%i
  12.                 exit /b
  13.         )
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢

查看全部评分

发表于 2015-2-11 22:30:05 | 显示全部楼层
  1. @echo off
  2. sed -i "11s/$/\n/" 1.txt
  3. sed -i "11,12!d" 1.txt
复制代码

评分

参与人数 2技术 +2 收起 理由
思想之翼 + 1 感谢
CrLf + 1 不潜水的都是好同志

查看全部评分

您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-19 18:04 , Processed in 0.018239 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表