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

[日期时间] 批处理如何按指定数量生成在指定时间范围内随机不重复的时间点

单位签到机坏了,上级单位要求不能中断上报签到信息
求助能生成签到 文件的批处理

求生成 每天4次的签到文本
时间区间分别是:7:30-8:30
11:30-12:30
14:00-14:30
17:30-18:00
要求时间是顺序的 人员出现是随机不重复的
1

评分人数

本帖最后由 pcl_test 于 2016-12-1 20:26 编辑

在论坛找了一下  人员随机问题可以解决
区间随机时间顺序问题还不知如何下手
http://www.bathome.net/redirect. ... 2814&ptid=20850

TOP

本帖最后由 pcl_test 于 2016-12-2 08:55 编辑

上班可提早,下班常延迟,在指定时间段内产生跟人数等量的不重复时间点再随机与ID和人名组合
7:30-8:30相差60分钟,60*60-2=3598秒,假设有50人,则每间隔3598/50≈71秒打一次卡
  1. @echo off&setlocal enabledelayedexpansion
  2. set t=07:30:00
  3. for /l %%i in (1 1 50) do (
  4.     set r=71
  5.     for /f "tokens=1-3 delims=:" %%a in ("!t!") do (
  6.         set /a h=1%%a-100,m=1%%b-100,s=1%%c-100
  7.         for %%d in (s m h) do (
  8.             set /a "v=%%d,%%d=(%%d+r)%%60,r=(v+r)/60"
  9.         )
  10.        set /a h=100+h,m=100+m,s=100+s
  11.        set t=!h:~-2!:!m:~-2!:!s:~-2!
  12.        echo;!t!
  13.     )
  14. )
  15. pause
复制代码
  1. @echo off
  2. rem win7及以上系统运行
  3. for /f "delims=" %%a in ('more +7 "%~f0"') do call set "list=%%list%%%%a;"
  4. set start=11:30
  5. set end=12:30
  6. powershell -c "$list=@{%list%};$len=$list.count;$array=Get-Random (1..$len) -count $len;$a=(New-TimeSpan %start% -end %end%).TotalSeconds;$t=(Get-Date %start%);$r=0;while($r -le ($len-1)){'time=\"{0}\" id=\"{1}\" name=\"{2}\"' -f $t.ToString('yyyy-MM-dd HH:mm:ss'),$array[$r],$list[$array[$r]];$r++;$t=(Get-Date $t).AddSeconds((Get-Random -min ([int](($a-2)/$len/2)) -max ([int](($a-2)/$len))))}"
  7. pause&exit
  8. 1='陈一'
  9. 2='黄二'
  10. 3='张三'
  11. 4='李四'
  12. 5='王五'
  13. 6='赵六'
  14. 7='钱七'
  15. 8='孙八'
  16. 9='杨九'
  17. 10='吴十'
复制代码

TOP

感谢版主大人的回复,第一段代码 可以实现生成顺序的时间 但不是随机的

TOP

本帖最后由 pcl_test 于 2016-12-6 04:53 编辑

回复 4# tuquan
  1. @echo off&setlocal enabledelayedexpansion
  2. set start=07:30:00
  3. set end=08:30:00
  4. for /f "delims=" %%a in ('wmic path win32_operatingsystem get LocalDateTime /value ^| findstr "="') do set %%a
  5. set /a "a=(1%start:~,2%-100)*3600+(1%start:~3,2%-100)*60, b=(1%end:~,2%-100)*3600+(1%end:~3,2%-100)*60"
  6. for /f "tokens=1,2 delims==" %%a in ('more +22 "%~f0"') do set _%%a=%%b&set "#!random!_%%a=%%a"
  7. for /f "tokens=2 delims==" %%a in ('set #') do set /a n+=1&set #!n!=%%a
  8. set /a c=(b-a-2)/n
  9. (for /l %%i in (1 1 %n%) do (
  10.     set /a "r=!random!%%(c/2)+(c/2+1)"
  11.     for /f "tokens=1-3 delims=:" %%a in ("!start!") do (
  12.         set /a h=1%%a-100,m=1%%b-100,s=1%%c-100
  13.         for %%d in (s m h) do (
  14.             set /a "v=%%d,%%d=(%%d+r)%%60,r=(v+r)/60"
  15.         )
  16.        set /a h=100+h,m=100+m,s=100+s,i+=1
  17.        set start=!h:~-2!:!m:~-2!:!s:~-2!
  18.        set /p=time="%LocalDateTime:~0,4%-%LocalDateTime:~4,2%-%LocalDateTime:~6,2% !start!"
  19.        for %%j in (#!i!) do for %%k in (!%%j!) do echo; id="%%k" name="!_%%k!"
  20.     )
  21. ))<nul
  22. pause&exit
  23. 1=陈一
  24. 2=黄二
  25. 3=张三
  26. 4=李四
  27. 5=王五
  28. 6=赵六
  29. 7=钱七
  30. 8=孙八
  31. 9=杨九
  32. 10=吴十
复制代码

TOP

excel 函数 ="7:30"+RAND()*("8:30"-"7:30"),然后将单元格属性改为时间

想要多少个生成多少个,填到你的表里就好了

TOP

回复 6# flyinnet9


    好像不可以的哦
这个生成的时间不是顺序递增的 倒是在区间内随机生成的
签到吗 肯定时间早的在前面

TOP

回复 7# tuquan


    把时间先排个序,再用就可以了,即随机又递增。

TOP

回复 3# pcl_test


    不好意思 我这现在没有WIN7及以上系统的电脑 第二段还没做测试

TOP

回复 7# tuquan


    排序不就好了,excel基本功能

TOP

回复 10# flyinnet9


    一排序时间又变了

TOP

回复 11# tuquan


    因为你排的是公式。。。。。

方法一:copy到一个文本文件,再copy回来
方法二:copy后,在excel中选择“选择性粘贴”-->"数值"

TOP

回复 3# pcl_test


    第二段做了测试 可以实现了
谢谢版主大人
就是随机出来的第一个时间必然start=时间,不过问题不大 改一下初始时间就好了

TOP

回复 3# pcl_test


    不好意思 我再多问一句 第二段代码可不可以在XP系统(安装程序或补丁)下运行
单位的电脑不让装WIN7及以上系统

TOP

直接简单做一个签到机不就行了,还这么麻烦

TOP

返回列表