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

[文本处理] 批处理怎样提取txt文本每一行前几位字符并去除重复?

[复制链接]
发表于 2012-2-8 17:32:17 | 显示全部楼层 |阅读模式
本帖最后由 pcl_test 于 2016-7-30 19:11 编辑

本人新手,
我想取文本列中的前8位前并去掉重复。例如:
1.txt
123567890,aaaaabbbb
124567891,cccccdddd
987654211,eeeeefffff
得到的结果为 2.txt :
12345678
98765432
发表于 2012-2-8 18:15:08 | 显示全部楼层
本帖最后由 ivor 于 2012-2-8 20:49 编辑

看错题意
发表于 2012-2-8 18:32:51 | 显示全部楼层

  1. @echo off&setlocal enabledelayedexpansion
  2. (for /f "delims=" %%i in (1.txt) do (
  3.    set "str=%%i"
  4.    set "str=!str:~,8!"
  5.    if not defined !str! echo !str!
  6.    set "!str!=l"
  7. ))>2.txt
复制代码
发表于 2012-2-9 16:24:31 | 显示全部楼层
回复 3# lvsehuaxue


    set "!str!=l"
这个SET语句的作用是什么?
发表于 2012-2-9 17:34:09 | 显示全部楼层
回复 4# wei121676
定义!str!,配合前面的语句除去重复的内容。
set "!str!=l"改成set "!str!=a"也可以。要想真正学习批处理,建议从基础学起。否则,即便别人给你讲了,你肯能也不懂?
发表于 2012-2-9 22:56:08 | 显示全部楼层
123567890,aaaaabbbb
124567891,cccccdddd

楼主,你的第一行和第二行不重复啊,为何要删掉呢?
发表于 2012-2-9 23:02:23 | 显示全部楼层
回复 6# find
从楼主的意思看,他可能是笔下无!
发表于 2012-2-9 23:05:31 | 显示全部楼层
  1. gawk -F "" "{i=$1$2$3$4$5$6$7$8;a[i]++;if(a[i]==1)print i}" a.txt >b.txt
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-21 10:00 , Processed in 0.029155 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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