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

[文本处理] [已解决]大文本,批处理如何实现指定列合并。

[复制链接]
发表于 2023-3-31 17:54:00 | 显示全部楼层 |阅读模式
如:
1.txt
因        yin        英        ying
……


实现:
2.txt
因英        yinying
……



原本是4列,合并后就是2列。
Excel 可以解决,但太慢了,我试着用gawk代码,好像不起作用,不知哪里的问题。
gawk -F '\t' '{print $1$3, $2$4}' 1.txt > 2.txt

评分

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

查看全部评分

发表于 2023-3-31 18:02:19 | 显示全部楼层
回复 1# 每天几分
  1. gawk -F "\t" "{print $1$3, $2$4}" 1.txt > 2.txt
复制代码
 楼主| 发表于 2023-3-31 18:41:31 | 显示全部楼层
回复 2# Batcher

不对,变3列了,
   

要这样才对
发表于 2023-3-31 19:29:37 | 显示全部楼层
请确保
无bom uft8编码
tab分割每列
斜杠n换行
发表于 2023-3-31 20:39:05 | 显示全部楼层
  1. @echo off
  2. (for /f "tokens=1-4" %%a in (1.txt) do (
  3.         echo %%a%%c        %%b%%d
  4. ))>2.txt
  5. pause
复制代码

批处理也不是很慢,我试了一下,百万行,1分钟

评分

参与人数 1技术 +1 收起 理由
Batcher + 1 乐于助人

查看全部评分

发表于 2023-3-31 20:46:26 | 显示全部楼层
看你的文本是
  1. 因\s\s\s\s\s\s\s\syin\s\s\s\s\s\s\s\s英\s\s\s\s\s\s\s\sying
复制代码
不是\t,所以要改一改
  1. gawk -F "[ \t]+" "{print $1$3,        $2$4}" 1.txt > 2.txt
复制代码

评分

参与人数 1技术 +1 收起 理由
Batcher + 1 乐于助人

查看全部评分

发表于 2023-3-31 21:48:39 | 显示全部楼层
回复 3# 每天几分


请把你的1.txt传上来,看看分隔符到底是空格还是制表符。
如果需要上传文件,可以用阿里云盘或百度网盘。
 楼主| 发表于 2023-3-31 22:08:57 | 显示全部楼层
本帖最后由 每天几分 于 2023-3-31 22:18 编辑

回复 7# Batcher


    就是制表符啊,复制到论坛就变很多个空格了。可以了,utf8编码的问题。
发表于 2023-3-31 22:18:33 | 显示全部楼层
回复 8# 每天几分


请把你的1.txt传上来,看看分隔符到底是空格还是制表符。
如果需要上传文件,可以用阿里云盘或百度网盘。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-19 01:02 , Processed in 0.020135 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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