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

[文本处理] [已解决]批处理怎样把每行都有的10位数字按行重写?

TXT   GBK   每行都有3个 不同的10位数字  能否直接把10位数字变成一样的 并且该数字每行增加3000
内容示例  2行:
INSERT INTO `dede33_archives` VALUES('1','10','0','1262245911','c','1','1','-2','0','0','引起痛经几大病症(图)','','','','','','1268045911','1267115111','1','痛经,引起几大病症(图)','0','0','0','0','0','引起痛经的几大病症(图),健康','','0','0','0');
INSERT INTO `dede33_archives` VALUES('2','10','0','1261145911','c','1','1','-2','0','0','经期不适试喝玫瑰花茶俏丽逛街装','','','admin','未知','/uploads/allimg/100307/2103595C7-0.jpg','1267045911','1267945011','1','孕前,适可尝试喝玫瑰花茶(','0','0','0','0','0','经期不适可尝试喝玫瑰花茶(图),健康','','0','0','0');

每行都有3个10位数字哦   只有这个特征 我都无法用什么来表达了.....

请从第一行开始 3个10位数都变  1295097000
第2行 就在上行得到的数字上+3030  3个10位数字变成  1295100030
第3行 变 1295103060
...........一直接下去  只变这3个数字哦

希望哪位朋友能帮帮我 谢谢
1

评分人数

    • Batcher: 感谢给帖子标题标注[已解决]字样PB + 2

请问楼主1295097000与第一行的三个数字有什么联系?如何运算得来的
***共同提高***

TOP

暂时没有找到好方法
  1. @echo off&setlocal enabledelayedexpansion
  2. (for /f "delims=" %%a in (a.txt) do (
  3.     set "str=%%a"&set "str=!str:''=' '!"
  4.     if not defined n (
  5.        set /a n=129509700
  6.        ) else (
  7.        set /a n+=3030
  8.     )
  9.     for /f "tokens=5,18,19 delims=,'" %%a in ("!str!") do (
  10.         for %%i in (!n!) do (
  11.             set "str=!str:%%a=%%i!"
  12.             set "str=!str:%%b=%%i!"
  13.             set "str=!str:%%c=%%i!"
  14.         )
  15.     )
  16.     echo !str:' '=''!
  17. ))>tem
  18. del /q a.txt&ren tem a.txt
  19. start a.txt
复制代码
1

评分人数

***共同提高***

TOP

貌似这样加下去很快就会超过cmd的计算范围了
  1. @echo off
  2. set /a n=1295097000-3030
  3. for /f "delims=" %%i in (a.txt) do (
  4.    set "str=%%i"
  5.    set /a n+=3030
  6.    setlocal enabledelayedexpansion
  7.    set aus=!str:'= !
  8.    for %%j in (!aus!) do (
  9.        set var=%%ja&set num=%%j
  10.        for /l %%L in (0 1 9) do (
  11.           set var=!var:%%L=!
  12.           set num=!num:%%L= %%L !
  13.        )
  14.        if "!var!"=="a" (
  15.           set i=0
  16.           for %%j in (!num!) do set /a i+=1
  17.           if !i! equ 10 (
  18.              set num=!num: =!
  19.              for %%j in (!num!) do (
  20.                  for %%k in (!n!) do set str=!str:%%j=%%k!
  21.              )
  22.            )
  23.         )
  24.     )
  25.     echo !str!
  26.     endlocal
  27. )
  28. pause
复制代码
1

评分人数

技术问题请到论坛发帖求助!

TOP

谢谢 两位  已经解决 能实现  太爽了

TOP

返回列表