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

[文本处理] 批处理如何快速按照列规则合并文本?

[复制链接]
发表于 2011-8-3 09:45:35 | 显示全部楼层 |阅读模式
本帖最后由 strong12345 于 2011-8-3 09:46 编辑

文本1内容
  1. 这是测试
  2. 你好
  3. aaaaaaa
  4. ^&*$0__@_@
复制代码
文本2内容
  1. 这是实战
  2. 晚安
  3. bbbbbbbb
  4. *(){}---(  ̄ c ̄)y▂ξ
复制代码
想把他合并成
  1. //这是测试//这是实战//
  2. //你好//晚安//
  3. //aaaaaaa//bbbbbbbb//
  4. //^&*$0__@_@//*(){}---(  ̄ c ̄)y▂ξ//
复制代码
请问除了for读取文本,依序行输出外,有没有比较高效率的方法?
 楼主| 发表于 2011-8-3 12:11:05 | 显示全部楼层
本帖最后由 strong12345 于 2011-8-3 12:13 编辑

此法不错
体会到 set /p 的应用经随
可是尚未解决我的问题
我的文档有6万多行,包含各种乱码(几乎都是乱码)
用此法有些乱码会导致处理错误....

正在尝试修改代码为我是和使用的方案
感谢
发表于 2011-8-3 13:02:20 | 显示全部楼层
  1. paste -d "/" a.txt b.txt | sed "s#/#//#;s#^#//#;s#$#//#" | more >c.txt
复制代码
发表于 2011-8-4 13:14:52 | 显示全部楼层
本帖最后由 Hello123World 于 2011-8-4 13:28 编辑

回复 2# else
findstr 的/n参数可以省略:
一般我都是喜欢把setlocal加在行首,这种哪里需要延迟加在哪里的方法确实令思路更加严谨。
  1. @echo off
  2. @Echo off
  3. (For /f "delims=" %%a in ('Findstr  .* 1.txt') do (
  4.   Set "a=%%a"
  5.   Setlocal enabledelayedexpansion
  6.   Set /p b=
  7.   Echo \\!a!\\!b!
  8.   Endlocal
  9. ))<2.txt>3.txt
  10. 3.txt
  11. pause>nul
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-17 22:07 , Processed in 0.017217 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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