标题: [文本处理] 求助批处理如何实现txt中有8000行合并成一行 [打印本页]
作者: seekbook 时间: 2022-1-13 21:38 标题: 求助批处理如何实现txt中有8000行合并成一行
- @echo off
- setlocal enabledelayedexpansion
- cd /d "%~dp0"
- set "str="
- for /f "delims=" %%i in ('type "a.txt"') do (
- set "line=%%i"
- set str=!str!,!line!
- )
- >"a_New.txt" echo !str:~1!
复制代码
大家好,我新开个贴子,上次可能表达清楚,以上代码只能实现合并2000条,但是如果超过5000条,8000条的时候,后面的就无法合并了,哪位朋友能帮忙测试改进下,非常感谢
作者: Batcher 时间: 2022-1-13 22:09
回复 1# seekbook
这段代码实现不了你想要的功能,不要在这个思路上面浪费时间了。
请反馈一下这个代码执行之后结果如何:
http://bbs.bathome.net/thread-61290-1-1.html#pid250233
作者: for_flr 时间: 2022-1-14 09:28
- @echo off
- powershell -c "(gc a.txt -readcount 0) -join ''|sc new_a.txt"
复制代码
作者: aloha20200628 时间: 2022-1-14 10:21
批处理有些短版不能碰,常见的两个就是变量的字符长度限于8K,超限自己就挂了;还有一个就是可以正常读写ansi编码(对简中系统即windows-936)的文本文件,但对其他编码就有麻烦了...
作者: seekbook 时间: 2022-1-14 13:24
回复 2# Batcher
谢谢管理,那个已经反馈过了,可以了,麻烦帮忙把那个贴显示已处理
作者: seekbook 时间: 2022-1-14 13:25
回复 4# aloha20200628
谢谢,明白了,原来是8K字的上限,我现在唯一能想到的是先进行多段分割了
作者: seekbook 时间: 2022-1-14 13:25
回复 3# for_flr
你好,这个是往代码中哪一段加呢,可以实现合并1万行吗
作者: aloha20200628 时间: 2022-1-14 14:42
试一试这杆纯P老枪...
for /f "usebackq delims=" %%s in ("a.txt") do (set/p=%%s<nul))>"a_New.txt.txt"
作者: for_flr 时间: 2022-1-14 15:13
回复 7# seekbook
单独保存为bat文件即可,实测30万行合并只需6秒
作者: xczxczxcz 时间: 2022-1-14 19:05
回复 9# for_flr
这个功能简单,这个时间应该算是爬速,再该就会出现亳秒级!
作者: seekbook 时间: 2022-1-14 20:07
回复 9# for_flr
感谢大佬,测试可以实现,就是怎么样实现在每行后面加个逗号的功能呢,麻烦帮我再改一下可以吗谢谢,我原来的代码可以加入逗号
作者: seekbook 时间: 2022-1-14 20:12
回复 8# aloha20200628
谢谢指导,好像测试了一下不行,7楼大佬这个可以
作者: for_flr 时间: 2022-1-14 20:14
回复 11# seekbook - @echo off
- powershell -c "(gc a.txt -readcount 0) -join ','|sc new_a.txt"
复制代码
作者: seekbook 时间: 2022-1-14 23:17
回复 13# for_flr
非常感谢热心大佬,解决了我困惑多日的问题
作者: aloha20200628 时间: 2022-1-15 13:01
备注》(for /f "usebackq delims=" %%s in ("a.txt") do (set/p=%%s<nul))>"a_New.txt" 此句式有效运行的前提是先执行 @echo off 更正如下:
@echo off
(for /f "usebackq delims=" %%s in ("a.txt") do (set/p=%%s<nul))>"a_New.txt"
【用时参考】常用的 echo "..." >a.txt 会同时输出换行符和双引号,而 set/p="..."<nul>a.txt 不会,但其也有限制,如会剔除头部空格,还会删除首字符为分号的整行数据...
欢迎光临 批处理之家 (http://bbs.bathome.net/) |
Powered by Discuz! 7.2 |