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

【练习-062】找出文本中内容完全相同的列

出题目的:
    强化字符处理能力;
    复习变量赋值法。
解题要求:
    代码简洁、高效;
    不生成临时文件。
加分原则:
    代码技术含量高,技巧出众的加技术分1分;
    pb加分上限20分(本主题同一id各贴累计),视代码精悍程度加分;
    批处理新人积极参与解题或讨论的可获额外参与奖励2pb(本主题同一id各贴累计)。
题目如下:
    有一文本a.txt(见附件)共50行50列(以tab为列分隔符),其中每行每列的字符串是由a-z以及空格、_、
#、$、.30个字符组合而成的,现知道其中有若干列的内容是相同的,要求找出各自相同的列组合并输出其共
同的内容,在这其中要注意如下的两列是不能视为内容相同(眼睛是可以判断出,但代码中就要考虑了):
    abc     abc
    m_空格  m_
    k $      空格k$
链接: https://pan.baidu.com/s/1AI27WrBgDbfMGgXEN7IIXg?pwd=ybun
----------------------------------------------------------------------------------------------------------------------------------------
代码运行标准输出(含升序处理):
  1. 5列 12列内容相同,列内容如下:
  2. fh xs|r|_cwq|unrjh|ebbk|bm|tv|_yy|a $z|onph|unw|ms|xi|dv|vcsya|t|s._|i|f|titm$|
  3. ioz|h_|n.b|wv_m|su|bmi| h_|paxvv|zzl|rsqiy|b|fp|nqdm.|_no|q|b|d.|lf|d in|pl|..cx
  4. |tui|woe|yst|rkpnq|z|.wwo|wyq|zwch|nisle
  5. 9列 26列内容相同,列内容如下:
  6. i|lgxeo|ybfep|as| rp| trzl|gc|chr|gj|b|a.n|q|f|v|e|hzwwl|aw|_zjet|o|_|j|f|zepyn
  7. |$.ma|s|ocdvw|jep|ud|x|pmu|ywlni|$wnle| bflz|wciuq|o|fr og|.$amq|ub|qkqh|g|f|s.x
  8. |g|xc|em|mc|c|o|ajb|as
  9. 18列 31列内容相同,列内容如下:
  10. hok|_z |va|mi|h.x$|u|s|k_|almdx|kkp|j|t|$aeg|yvn|se r|ylw|dzv|so_|ltn|vtokb|yyf
  11. c|a|ql.n|uom|mouvn|fbgr|_|.sid|b|dpb|rrnb$|__fay|d|ewck|w |q|na|ecoj|r_h|h|l|i|x
  12. l|ame|x$|ynin_|cq|hc$l|$.io|gnigp
  13. 38列 41列 47列内容相同,列内容如下:
  14. eez|yq|fgbq|aeazh|k.u|phnw|byj$|ke|onr.q|a pum|frf|qem$t|qpskt|vqpto|nwm|qm yx|
  15. vyw|szrc|xfcee|_|xfx|x$sxu|l|iw|hg|je$rr|yj|vr |i.alj|ew|hio|y|iz|bw|ctl|kvbzi|j
  16. fp|bm|qvuyt|yioz |fs|vvi$|iq t|vo|e|pv|t|hxkqe|sayds|c
复制代码
***共同提高***

要求找出各自相同的列组合并输出其共同的内容

没看懂~
技术问题请到论坛发帖求助!

TOP

回复 2楼 的帖子

就是找出a.txt中完全相同的列,这有可能是3 5 12列相同,同时21 49列相同,输出其共同的内容即为输出这些相同列的内容(在一行内输出,中间用|格开)。

[ 本帖最后由 batman 于 2011-3-10 19:15 编辑 ]
***共同提高***

TOP

新手可以先尝试着生成a.txt这样的文本,有助于打开解题思路。。。
***共同提高***

TOP

先发个
  1. @echo off&setlocal enabledelayedexpansion
  2. set "Tab=    "这里改为跳格键
  3. for /f "delims=" %%i in (a.txt) do (
  4.     set "str=%%i"
  5.     set "str="!str:%Tab%="%Tab%"!""
  6.     for %%j in (!str!) do (
  7.         set "var=!str:*%%j=!"
  8.         set "var1=!var:*%%j=!"
  9.         if "!var!" neq "" if "!var!" neq "!var1!" set "Tem=!Tem! %%~j"
  10.     )
  11.     echo!Tem!&set Tem=
  12. )
  13. pause
复制代码
[]

TOP

不知道我有没有理解错
  1. @echo off&setlocal enabledelayedexpansion
  2. for /f "tokens=1* delims=:" %%a in ('findstr /n .* a.txt') do (
  3. set /p=第%%a行:  <nul
  4. set tmp=%%b
  5. for %%c in ("!tmp: =" "!") do (
  6. if "!.%%a%%c!"=="" (set ".%%a%%c=.") else set /p=%%~c   <nul
  7. )
  8. echo;
  9. )
  10. pause
复制代码

TOP

回复 6楼 的帖子

理解错误,难道这题这么难理解!
***共同提高***

TOP

在列里找相同吗?
  1. @echo off&setlocal enabledelayedexpansion
  2. set "Tab= "这里改为跳格键
  3. for /f "delims=" %%i in (_a.txt) do (
  4.     set "str=%%i"
  5.     set n=
  6.     for %%j in ("!str:%Tab%="%Tab%"!") do (
  7.         set /a n+=1
  8.         for %%k in (!n!) do set l_%%k=!l_%%k!%Tab%%%j
  9.     )
  10. )
  11. for /l %%i in (1 1 %n%) do (
  12.     for %%j in (!l_%%i!) do (
  13.         set "var=!l_%%i:*%%j=!"
  14.         if "!var!" neq "" if "!var!" neq "!var:*%%j=!" set "Tem=!Tem! %%~j"
  15.     )
  16.     if defined Tem echo %%i列:!Tem!&set Tem=
  17. )
  18. pause
复制代码

TOP

  1. @echo off&setlocal enabledelayedexpansion
  2. ::将下面的[tab]改为实际的跳格键
  3. set "tab=[tab]"
  4. for /f "delims=" %%a in (a.txt) do (
  5.   set "str=%%a"
  6.   for /l %%b in (1 1 50) do (
  7.     for /f "delims=%tab%" %%c in ("!str!") do set "_%%b=!_%%b!批%%c"&set "str=!str:*%tab%=!"
  8.   )
  9. )
  10. echo,与前面列存在重复的列有:
  11. for /f "tokens=1* delims==" %%h in ('set _') do (
  12.   if "!%%i!"=="a" set "var=%%i"&echo,第%%h列:!var:批= !"
  13.   set "%%i=a"
  14. )
  15. pause>nul
复制代码

[ 本帖最后由 weichenxiehou 于 2011-3-10 19:02 编辑 ]
1

评分人数

    • batman: 积极参与最重要PB + 2
看得多说得多,远比不上写得多。

TOP

回复 9楼 的帖子

题意还只有你理解对了,但结果不正确,请修改。。。

[ 本帖最后由 batman 于 2011-3-10 19:05 编辑 ]
***共同提高***

TOP

回复 8楼 的帖子

题意还是没有理解对,难道我表达能力这么差!题目是要找出a.txt中所有彼此相同的列啊。。。

[ 本帖最后由 batman 于 2011-3-11 00:16 编辑 ]
***共同提高***

TOP

回复 10楼 的帖子

谢谢加分!我把我的代码执行结果跟11楼对比了下,多显示了一行,代码修改了一下,就是没列出哪些列是一样的,只把这些列的内容打印出来了:
  1. @echo off&setlocal enabledelayedexpansion
  2. ::将下面的[tab]改为实际的跳格键
  3. set "tab=[tab]"
  4. for /f "delims=" %%a in (a.txt) do (
  5.   set "str=%%a"
  6.   for /l %%b in (1 1 50) do (
  7.     for /f "delims=%tab%" %%c in ("!str!") do set "_%%b=!_%%b!批%%c"&set "str=!str:*%tab%=!"
  8.   )
  9. )
  10. echo,相同的列有:
  11. for /f "tokens=1* delims==" %%h in ('set _') do (
  12.   if "!%%i!"=="a" set "var=%%i"&echo,!var:批= !"
  13.   set "%%i=!%%i!a"
  14. )
  15. pause>nul
复制代码

[ 本帖最后由 weichenxiehou 于 2011-3-10 21:00 编辑 ]
看得多说得多,远比不上写得多。

TOP

回复 12楼 的帖子

重要也是最难点就是列出这些相同的列组,请继续修改
***共同提高***

TOP

回复 13楼 的帖子

  1. @echo off&setlocal enabledelayedexpansion
  2. ::将下面的[tab]改为实际的跳格键
  3. set "tab=[tab]"
  4. for /f "delims=" %%a in (a.txt) do (
  5.   set "str=%%a"
  6.   for /l %%b in (1 1 50) do (
  7.     for /f "delims=%tab%" %%c in ("!str!") do set "_%%b=!_%%b!批%%c"&set "str=!str:*%tab%=!"
  8.   )
  9. )
  10. echo,相同的列有:
  11. set n=
  12. for /f "tokens=1* delims==" %%h in ('set _') do (
  13.   if "!%%i!"=="" set/a n+=1&set "#!n!=%%i"
  14.   set "%%i=!%%i!%%h"
  15. )
  16. for /l %%j in (1 1 %n%) do (
  17.   set num=!#%%j!
  18.   call,set value=%%!num!%%
  19.   for /f "tokens=1-3 delims=_" %%x in ("!value!") do if not "%%y"=="" echo,第%%x %%y %%z列,内容为:!num:批= !
  20. )
  21. pause>nul
复制代码
效率不高,见谅。

[ 本帖最后由 weichenxiehou 于 2011-3-10 22:25 编辑 ]
1

评分人数

    • batman: 再尝试用两个for循环解决PB + 10
看得多说得多,远比不上写得多。

TOP

呃,终于明白了,貌似不太难...这么长的行,我感觉用眼睛更判断不了
  1. @echo off&setlocal enabledelayedexpansion
  2. ::将下面的[tab]改为实际的跳格键
  3. set "tab=        "
  4. for /f "delims=" %%a in (a.txt) do (
  5.         set "tmp=%%a"
  6.         for %%b in ("!tmp:        =" "!") do (
  7.                 set /a n=n%%50+1
  8.                 for %%z in (!n!) do set .!n!=!.%%z!^|%%~b
  9.         )
  10. )
  11. for /l %%a in (1 1 50) do (
  12.         set tmp=
  13.         for %%b in ("\!.%%a!") do set tmp=!%%~b!
  14.         set \!.%%a!=*!tmp! %%a列
  15. )
  16. for /f "tokens=1* delims=\=*" %%a in ('set\^|findstr "**"') do (
  17. echo 第%%b相同,内容为:
  18. echo %%a
  19. )
  20. pause
复制代码
1

评分人数

    • batman: 可再尝试升序处理PB + 12

TOP

返回列表