标题: [文本处理] 批处理怎样提取txt文本每一行前几位字符并去除重复? [打印本页]
作者: jimmyche 时间: 2012-2-8 17:32 标题: 批处理怎样提取txt文本每一行前几位字符并去除重复?
本帖最后由 pcl_test 于 2016-7-30 19:11 编辑
本人新手,
我想取文本列中的前8位前并去掉重复。例如:
1.txt
123567890,aaaaabbbb
124567891,cccccdddd
987654211,eeeeefffff
得到的结果为 2.txt :
12345678
98765432
作者: ivor 时间: 2012-2-8 18:15
本帖最后由 ivor 于 2012-2-8 20:49 编辑
看错题意
作者: lvsehuaxue 时间: 2012-2-8 18:32
- @echo off&setlocal enabledelayedexpansion
- (for /f "delims=" %%i in (1.txt) do (
- set "str=%%i"
- set "str=!str:~,8!"
- if not defined !str! echo !str!
- set "!str!=l"
- ))>2.txt
复制代码
作者: wei121676 时间: 2012-2-9 16:24
回复 3# lvsehuaxue
set "!str!=l"
这个SET语句的作用是什么?
作者: lvsehuaxue 时间: 2012-2-9 17:34
回复 4# wei121676
定义!str!,配合前面的语句除去重复的内容。
set "!str!=l"改成set "!str!=a"也可以。要想真正学习批处理,建议从基础学起。否则,即便别人给你讲了,你肯能也不懂?
作者: find 时间: 2012-2-9 22:56
123567890,aaaaabbbb
124567891,cccccdddd
楼主,你的第一行和第二行不重复啊,为何要删掉呢?
作者: lvsehuaxue 时间: 2012-2-9 23:02
回复 6# find
从楼主的意思看,他可能是笔下无!
作者: find 时间: 2012-2-9 23:05
- gawk -F "" "{i=$1$2$3$4$5$6$7$8;a[i]++;if(a[i]==1)print i}" a.txt >b.txt
复制代码
欢迎光临 批处理之家 (http://www.bathome.net/) |
Powered by Discuz! 7.2 |