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

[文本处理] 求批处理:依据文本空行来分割成独立带编号的.txt文件

[复制链接]
发表于 2018-12-12 18:12:11 | 显示全部楼层 |阅读模式
依据文本内容里面的空行来分割成独立带编号的.txt文件,最好编号也能自定义,比如20181212-01、20181212-02、20181212-**
搜索了几个小时都没有找到合适的,请求哪位老大给个准确的批处理代码!
 楼主| 发表于 2018-12-12 19:23:44 | 显示全部楼层
已经知道了 谢谢!
发表于 2018-12-12 19:24:42 | 显示全部楼层
本帖最后由 yhcfsr 于 2018-12-12 19:29 编辑

上个版本有BUG,遇到一些特殊英文字符会丢数据,特此更新
  1. @echo off

  2. rem 设置源文件
  3. set "TXT=C:\Users\CaoFei\Desktop\test.txt"
  4. if not exist "%TXT%" echo;源文件不存在&pause&exit

  5. set "dd=%date:~,4%%date:~5,2%%date:~8,2%"
  6. set "n=101"

  7. for /f "tokens=1,*delims=:" %%a in ('findstr /n ".*" "%TXT%"') do (
  8.         set "str=%%b"
  9.         if "%%b"=="" set/a "n+=1"
  10.         setlocal enabledelayedexpansion
  11.         if "%%b" neq "" echo;!str!>>"%dd%-!n:~-2!.txt"
  12.         endlocal
  13. )
  14. pause
复制代码
发表于 2018-12-12 19:41:58 | 显示全部楼层
  1. @echo off
  2. set "srcfile=1.txt"
  3. powershell -Command "$file='%srcfile%';$dstDir='%~dp0';$n=1;$date=Get-Date -Format 'yyyyMMdd';[regex]::Split([System.IO.File]::ReadAllText($file,[System.Text.Encoding]::Default),'^\s*\n',[System.Text.RegularExpressions.RegexOptions]::Multiline)|Where-Object{$_ -notmatch '^\s*$'}|ForEach-Object{Set-Content -LiteralPath ($dstDir + $date +'-' + $n + '.txt') -Value $_ -Encoding Default;$n++}"
  4. pause
  5. exit /b
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-21 01:21 , Processed in 0.029369 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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