[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文本处理] 批处理如何删除txt中每行开头指定字符前的字符串重复出现次数超过指定次数的行?

本帖最后由 pcl_test 于 2016-7-7 22:42 编辑

huangbaohua|1979601521huang
huangbaohua|1979601521huang
857084682|5678967890
lapo5363|466742517
sishenlaile|yytl1103
优雅先生|1986315
优雅先生|198631215
优雅先生|19812631215
优雅先生|1981231aaa6315
优雅先生|1986312342345
优雅先生|1986315

雨姬|681122
前度|19840924

我就是想吧一个文本内,“|”前的内容超过5行的内容,删除掉

如上内容  优雅先生,优雅先生超过5行,就是想将  优雅先生的那行内容全部删除

最好就是文本1 处理后,导出为 文本2

本帖最后由 batman 于 2013-7-24 20:17 编辑
  1. @echo off&setlocal enabledelayedexpansion
  2. for /f "tokens=1* delims=|" %%a in (1.txt) do set /a n+=1,.%%a+=1&set "_!n!=%%a|%%b"
  3. (for /l %%a in (1,1,%n%) do (
  4.   for /f "tokens=1* delims=|" %%b in ("!_%%a!") do if !.%%b! leq 5 echo,%%b^|%%c
  5. ))>2.txt
  6. start 2.txt
复制代码
***共同提高***

TOP

回复 2# batman


    按照你的代码,如果是超过10行删除的话是不是 吧 “5” 修改为“10“就好了

TOP

Try it, then you can understand...
***共同提高***

TOP

回复 4# batman

    数据处理效率不是很好

6MB的文本,里面行数有超过32行的,处理中,就提示如图显示

TOP

纯P,这大文本你期待多快?
|符号的前面,你有些有特殊字符吧,像空格什么的,你举的例子并未列出来...
不行把文本压缩下传到网盘,把下载地址贴出来
  1. @echo off&setlocal enabledelayedexpansion
  2. for /f "delims=|" %%a in ('sort 1.txt') do (
  3.         set "str5=!str4!"
  4.         set "str4=!str3!"
  5.         set "str3=!str2!"
  6.         set "str2=!str1!"
  7.         set "str1=%%a"
  8.         if "!str5!"=="!str1!" (
  9.          if not defined . (
  10.          set .=.
  11.          set "#=!#!/ic:"%%a^|" "
  12.          )
  13.         ) else set .=
  14. )
  15. if defined # (findstr /v %#% 1.txt>2.txt)else copy /y 1.txt 2.txt
复制代码
初学BAT,非专业。代码不适当之处还望前辈们多多指点。在此表示感谢!

TOP

回复 6# xxpinqz


    我处理的文件就是这样的, 你看下

有时候是几万 条

TOP

大文本建议用第三方神器 gawk,爽爽的:
  1. @gawk -F"|" "FNR!=NR&&ar[$1]<5;{ar[$1]+=1}" 1.txt 1.txt>2.txt
复制代码
1

评分人数

    • Rasm: 感谢您!技术 + 1

TOP

回复 8# CrLf


    如果是想删除小于| 前面的重复数,该怎么修改这个代理

比如想删除小于5个|重复数,正好与你这个相反

TOP

回复 9# Rasm


    以顶楼数据为例,希望得到什么结果?

TOP

回复 10# ShowCode


huangbaohua|19796uang
huangbaohua|197960
huangbaohua|1979601521
huangbaohua|1979601
huangbaohua|191huang
857084682|5678967890
lapo5363|466742517
sishenlaile|yytl1103
优雅先生|1986315
优雅先生|198631215
优雅先生|19812631215
优雅先生|1981231aaa6315
优雅先生|1986312342345
优雅先生|1986315
雨姬|681122
前度|19840924


=================

以上数据为例,希望得到  |  前面的数值重复数在 5-8之间

如:

huangbaohua|19796uang
huangbaohua|197960
huangbaohua|1979601521
huangbaohua|1979601
huangbaohua|191huang
优雅先生|1986315
优雅先生|198631215
优雅先生|19812631215
优雅先生|1981231aaa6315
优雅先生|1986312342345
优雅先生|1986315

TOP

回复 10# ShowCode


    你把这时间和精力用来做别的事情,会更有意义。
去学去写去用才有进步。安装python3代码存为xx.py 双击运行或右键用IDLE打开按F5运行

TOP

回复 11# Rasm
  1. gawk -F "|" "{a[$1][n++]=$0}END{for(i in a){x=length(a[i]);if(x>=5&&x<=8){for(j in a[i])print a[i][j]}}}" 1.txt > 2.txt
复制代码
测试代码之前请做好备份

TOP

回复 13# ShowCode


    为什么处理结果是空的

TOP

回复 8# CrLf


    有些为什么不可以呢,中文的有些不行,没有筛选出来

TOP

返回列表