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

[文本处理] 【已解决】BAT或VBS:满足条件求数值,并导入文本

本帖最后由 思想之翼 于 2015-11-15 09:57 编辑

问题一、
一个五位数,比如56789,现在设定5是第1位,6是第2位,7是第3位,8是第4位,9是第5位
5位数各位置两两相加取尾数(比如56789的第1位+第2位:5+6=11,取尾数=1)有10种,即1+2、1+3、1+4、1+5、2+3、2+4、2+5、3+4、3+5、4+5
上述10种组合中,取不重复的4个为一组,比如 1+2、1+3、1+4、1+5 为一组,共有210个组合
这210个组合中,都有10000种形态
比如第1组
1+2可以=0123456789
1+3可以=0123456789
1+4可以=0123456789
1+5可以=0123456789
这样,第1组就可以组成0000-9999这10000种形态,分别是:
1+2=0
1+3=0
1+4=0
1+5=0

1+2=0
1+3=0
1+4=0
1+5=1

1+2=0
1+3=0
1+4=0
1+5=2
...
1+2=9
1+3=9
1+4=9
1+5=9

同样第2组、第3组...第210组,都有10000种形态

手工建立了名称为001-210这样210个文件夹,并在每个文件夹里手工建立了名称为00001.txt-10000.txt这样1万个文本。

∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷
现在,需要写一个批处理,在五位数 00000 - 99999 中
搜索符合第1组 1+2、1+3、1+4、1+5 为0000形态的数据
1+2=0
1+3=0
1+4=0
1+5=0
满足条件的五位数是 00000 19999 28888 37777 46666 55555 64444 73333 82222 91111
将其写入 D:/数据/001/00001.txt(数据横排,末尾加回车符;没有数据,则写入空)

搜索符合第1组 1+2、1+3、1+4、1+5 0001形态的数据
1+2=0
1+3=0
1+4=0
1+5=1
满足条件的五位数是 00001 19990 28889 37778 46667 55556 64445 73334 82223 91112
将其写入 D:/数据/001/00002.txt
...

搜索符合第1组 1+2、1+3、1+4、1+5 9999形态的数据
1+2=9
1+3=9
1+4=9
1+5=9
满足条件的五位数是 09999 18888 27777 36666 45555 54444 63333 72222 81111 90000
将其写入 D:/数据/001/10000.txt

∷∷∷∷∶∶∶∶∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷

搜索符合第2组1+2、1+3、1+4、2+3 0000形态的数据
1+2=0
1+3=0
1+4=0
2+3=0
满足条件的五位数是 00000 00001 00002 00003 00004 00005 00006 00007 00008 00009 55550 55551 55552 55553 55554 55555 55556 55557 55558 55559
将其写入 D:/数据/002/00001.txt(数据横排,末尾加回车符;没有数据,则导入空文本)

搜索符合第2组1+2、1+3、1+4、2+3 0001形态的数据
1+2=0
1+3=0
1+4=0
2+3=1
没有满足条件的五位数,就将空文本写入 D:/数据/002/00002.txt
...

搜索符合第2组1+2、1+3、1+4、2+3 9999形态的数据
1+2=9
1+3=9
1+4=9
2+3=9
没有满足条件的五位数,就将空文本写入 D:/数据/002/10000.txt

......

∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷
搜索符合第210组 2+5、3+4、3+5、4+5 0000形态的数据
2+5=0
3+4=0
3+5=0
4+5=0
满足条件的五位数是 00000 05555 10000 15555 20000 25555 30000 35555 40000 45555 50000 55555 60000 65555 70000 75555 80000 85555 90000 95555
将其写入 D:/数据/210/00001.txt(数据横排,末尾加回车符;没有数据,则导入空文本)

搜索符合第210组 2+5、3+4、3+5、4+5 0001形态的数据
2+5=0
3+4=0
3+5=0
4+5=1
没有满足条件的五位数,就将空文本写入 D:/数据/210/00002.txt
......

搜索符合第210组 2+5、3+4、3+5、4+5 9999形态的数据
2+5=9
3+4=9
3+5=9
4+5=9
没有满足条件的五位数,就将空文本写入D:/数据/210/10000.txt

这样的代码如何写?

∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷∷
问题二、
5位数各位置两两相减的绝对值,(比如56789的第1位、第2位相减的绝对值,即|5-6|=1)也有10种
即|1-2|、|1-3|、|1-4|、|1-5|、|2-3|、|2-4|、|2-5|、|3-4|、|3-5|、|4-5|
上述10种组合中,取不重复的4个为一组,比如|1-2|、|1-3|、|1-4|、|1-5|为一组,共有210个组合
这210个组合中,同样每组都有10000种可能
  
欲进行上述过程,搜索出210个组合中0000-9999形态的数据,并分别写入对应的文本
问题一的代码修改什么地方?

回复 22# 思想之翼

那就加个判断
  1. if exist "D:/数据/!n:~1!/!s:~1!.txt" (>>"D:/数据/!n:~1!/!s:~1!.txt" echo;) else >"D:/数据/!n:~1!/!s:~1!.txt" echo;
复制代码
1

评分人数

TOP

回复 21# terse

您给出的代码,是先添加未出现名称的空文本,再在所有文本中添加回车符,这样先前添加的空文本,也加了回车符
如果先在文本数据末尾添加回车符 ,再添加未出现名称的空文本,您给出的代码如何修改?

TOP

回复 20# 思想之翼

已经添加

TOP

回复 18# terse
感谢您的热心帮助!
在末尾添加如下代码  可以在001-210文件夹里  添加00001-10000之间未出现名称的空文本  然后全部文本添加回车符
如果要在001-210文件夹里所有文本数据末尾先添加回车符  然后再在001-210文件夹里添加00001-10000之间未出现名称的空文本,下列代码如何修改?
for /l %%i in (1001,1,1210) do (
    set n=%%i
     for /l %%j in (100001,1,110000) do (
         set s=%%j
         >>"D:/数据/!n:~1!/!s:~1!.txt" echo;
     )
)

TOP

本帖最后由 wankoilz 于 2015-11-9 17:15 编辑

练习awk!
感觉效率是个问题,100000个五位数共2千一百万个组合,仅仅是装入数组就花了34秒
如果再不停的写入文件,估计够呛。
以下代码针对第一个问题,仅仅是将2千一百万个组合装入数组,并没有实现写入文本,因为那样太慢,只当练手。
  1. # & cls & setlocal enabledelayedexpansion
  2. # & cls & echo !time! & echo; | gawk -f %0 >con & echo !time! & pause & exit
  3. END{
  4.      #将100000个“五位数”的共21000000个四位组合装入数组
  5.      s="0123456789"
  6. for(i=1;i<=length(s);i++){arr_num[i]=substr(s,i,1)}
  7. for(a=0;a<=9;a++){
  8.      for(b=0;b<=9;b++){
  9.      for(c=0;c<=9;c++){
  10.      for(d=0;d<=9;d++){
  11.      for(e=0;e<=9;e++){
  12.      str_5=a""b""c""d""e
  13. for(x=1;x<=5;x++){arr_str_5[x]=substr(str_5,x,1)}
  14. str_10=""
  15. for(f=1;f<=5;f++){
  16.      for(g=f+1;g<=5;g++){
  17.      remainder=(arr_str_5[f]+arr_str_5[g]) % 10
  18.      str_10=str_10""remainder
  19. }
  20. }
  21. count_210=0;str_4=""
  22. for(x=1;x<=10;x++){arr_str_10[x]=substr(str_10,x,1)}
  23. for(m=1;m<=10;m++){
  24.      for(n=m+1;n<=10;n++){
  25.      for(o=n+1;o<=10;o++){
  26.      for(p=o+1;p<=10;p++){
  27.      count_210+=1
  28.      str_4=arr_str_10[m]""arr_str_10[n]""arr_str_10[o]""arr_str_10[p]
  29.      arr_rem_com[str_5][count_210]=str_4
  30. }
  31. }
  32. }
  33. }
  34. }
  35. }
  36. }
  37. }
  38. }
  39. #测试查看19999的210个组合情况
  40. for(i=1;i<=210;i++){
  41.      print arr_rem_com[19999][i]
  42. }
  43. }
复制代码
gawk 4.1.0 下载地址:http://www.bathome.net/viewthread.php?tid=21366&highlight=gawk
为什么代码显示出的缩进会这么大....实际没这么夸张

TOP

回复 17# 思想之翼
问题1 问题2
在代码最后 加上
  1. for /l %%i in (1001,1,1210) do (
  2.     set n=%%i
  3.      for /l %%j in (100001,1,110000) do (
  4.          set s=%%j
  5.          >>"D:/数据/!n:~1!/!s:~1!.txt" echo;
  6.      )
  7. )
复制代码
问题3 将第11行代码 替换为
  1. set /a "n=%%i-%%j,$%%i_%%j=(n>>31|1)*n"
复制代码
1

评分人数

TOP

本帖最后由 思想之翼 于 2015-11-8 05:31 编辑

回复 16# terse
感谢您的帮助!
代码正在测试。有些问题还需您的帮助:
1、发现写入的文本数据末尾,没有添加回车符。
2、部分条件形态无数值,没有导入空文本。如果事后添加00001.txt-10000.txt之间未出现序号的空文本,这样的代码如何写?
3、如果是两两相减取绝对值,下句如何修改?
set /a "$%%i_%%j=(%%i+%%j)%%10"

TOP

  1. @ECHO OFF&setlocal enabledelayedexpansion
  2. for /l %%i in (0,1,9) do set /a _%%i=%%i+1
  3. for /l %%i in (1,1,4) do (
  4.     for /l %%j in (!_%%i!,1,5) do (
  5.         set /an+=1
  6.         set "$!n!=%%i %%j"
  7.     )
  8. )
  9. for /l %%i in (0,1,9) do (
  10.     for /l %%j in (0,1,9) do (
  11.         set /a "$%%i_%%j=(%%i+%%j)%%10"
  12.     )
  13. )
  14. for /l %%i in (1001,1,1210) do (
  15.     set n=%%i
  16.     md "D:/数据/!n:~1!" 2>nul
  17. )
  18. set n=1000
  19. for /l %%a in (1,1,7) do (
  20.     for /l %%b in (!_%%a!,1,10) do (
  21.         for /l %%c in (!_%%b!,1,10) do (
  22.             for /l %%d in (!_%%c!,1,10) do (
  23.                 set /an+=1
  24.                 for /l %%e in (100000,1,199999) do (
  25.                     set s=%%e
  26.                     for /f "tokens=1-8" %%1 in ("!$%%a! !$%%b! !$%%c! !$%%d!") do (
  27.                         for /f "tokens=1-4" %%i in ("!s:~%%1,1!_!s:~%%2,1! !s:~%%3,1!_!s:~%%4,1! !s:~%%5,1!_!s:~%%6,1! !s:~%%7,1!_!s:~%%8,1!") do (
  28.                             set /a t=10!$%%i!!$%%j!!$%%k!!$%%l!+1
  29.                             >>"D:/数据/!n:~1!/!t:~1!.txt" set /p =!s:~1! <nul
  30.                         )
  31.                     )
  32.                 )
  33.             )
  34.         )
  35.     )
  36. )
  37. pause
复制代码
1

评分人数

TOP

回复 14# wankoilz


    一点都没有。伸手党一直都是这些人。
我从09年到15年计算机水平没有进步过。不过解决问题大多靠自己查资料可以解决,不至于开口就问人要代码。
我最近贴的代码都是一边查资料一边写出来的。可见不难。水平要求并不高。

TOP

哈哈。猜啊猜。

实际你们这些伸手党问的问题,处理逻辑都不复杂,学门语言用不了多少时间。你们自己就是 ...
依山居 发表于 2015-11-7 19:52

兄弟有点过激了...

TOP

回复 8# B魔方大人
感谢!
代码运行时不时弹出确认按钮,也没有任何运算结果。

TOP

本帖最后由 思想之翼 于 2015-11-7 23:14 编辑

回复 9# terse
感谢详细说明。
您的思路我明白了。您的代码,将10选4组成210个组合后,然后将这个数的210个不重复的排列写入文件,如28888 含有的排列0000 就将28888写入00001.txt
问题就出在这。28888 含有排列0000,这是第1个组合里的排列0000,就需要将28888写入/001/00001.txt

我的初衷是,从单个条件考虑,符合某个条件的数值,就写入特意为这个条件建立的文件夹及文本。
210个组合,需要建立210个文件夹,210个文件夹内都需要建立00001.txt - 10000.txt的文本。

比如:
符合第一个组合的第一个条件
1+2=0
1+3=0
1+4=0
1+5=0
其数值是  00000 19999 28888 37777 46666 55555 64444 73333 82222 91111
就只将这组数值写入001文件夹内的00001.txt

符合第二个组合的第一个条件
1+2=0
1+3=0
1+4=0
2+3=0
其数值是 00000 00001 00002 00003 00004 00005 00006 00007 00008 00009
55550 55551 55552 55553 55554 55555 55556 55557 55558 55559
就只将这组数值写入002文件夹内的00001.txt

这样分组写入特定文本的数据,有重复。比如001文件夹内00001.txt 中有00000,002文件夹内00001.txt中也有00000

TOP

回复 10# 依山居

本来挺简单的逻辑,很容易被题主带入他设定好的思维中!&#128516;

TOP

哈哈。猜啊猜。

实际你们这些伸手党问的问题,处理逻辑都不复杂,学门语言用不了多少时间。你们自己就是不愿意自己学。

TOP

返回列表