Board logo

标题: [转载教程] PowerShell 技能长篇连载 - 2014 年 7 月第 2 辑 [打印本页]

作者: victorwoo    时间: 2014-7-11 23:55     标题: PowerShell 技能长篇连载 - 2014 年 7 月第 2 辑

本帖最后由 victorwoo 于 2014-7-12 00:04 编辑

查找两个日期之间的所有日子
http://blog.vichamp.com/powershe ... s-between-two-dates
复制命令行历史记录
http://blog.vichamp.com/powershe ... ing-command-history
复制命令行历史的工具函数
http://blog.vichamp.com/powershe ... d-history-as-a-tool
简单地读取注册表值
http://blog.vichamp.com/powershe ... istry-values-easily
接收多重输入
http://blog.vichamp.com/powershe ... ting-multiple-input
作者: victorwoo    时间: 2014-7-12 00:05

由于粘贴过来会丢失格式,所以只整理了链接,请见谅。
作者: Batcher    时间: 2014-7-12 12:15

代码放在code标签里面就可以了,比如:
http://bbs.bathome.net/thread-3473-1-1.html

如果您需要知道两个日期之间的间隔天数,那么可以用 New-TimeSpan 轻松地获得:
  1. $startdate = Get-Date
  2. $enddate = Get-Date -Date '2014-09-12'
  3. $difference = New-TimeSpan -Start $startdate -End $enddate
  4. $difference.Days
复制代码
然而,如果您不仅想知道两者之间的间隔天数,而且还希望精确地获取每一天的日期对象,那么可以用这个方法:
  1. $startdate = Get-Date
  2. $enddate = Get-Date -Date '2014-09-12'
  3. $difference = New-TimeSpan -Start $startdate -End $enddate
  4. $days = [Math]::Ceiling($difference.TotalDays)+1
  5. 1..$days | ForEach-Object {
  6.   $startdate
  7.   $startdate = $startdate.AddDays(1)
  8. }
复制代码
这一次,PowerShell 输出两个指定日期之间的所有日期对象。

当您了解了精确获取每个日期对象(而不仅是总天数)的方法之后,您可以过滤(例如以星期数),并查找距离您放假或退休之前还有多少个星期天或工作日。

以下代码是获取工作日用的:
  1. $startdate = Get-Date
  2. $enddate = Get-Date -Date '2014-09-12'
  3. $difference = New-TimeSpan -Start $startdate -End $enddate
  4. $difference.Days
  5. $days = [Math]::Ceiling($difference.TotalDays)+1
  6. 1..$days | ForEach-Object {
  7.   $startdate
  8.   $startdate = $startdate.AddDays(1)
  9. } |
  10.   Where-Object { $_.DayOfWeek -gt 0 -and $_.DayOfWeek -lt 6}
复制代码
这段代码时统计工作日天数用的:
  1. $startdate = Get-Date
  2. $enddate = Get-Date -Date '2014-09-12'
  3. $difference = New-TimeSpan -Start $startdate -End $enddate
  4. "Days in all: " + $difference.Days
  5. $days = [Math]::Ceiling($difference.TotalDays)+1
  6. $workdays = 1..$days | ForEach-Object {
  7.   $startdate
  8.   $startdate = $startdate.AddDays(1)
  9. } |
  10.   Where-Object { $_.DayOfWeek -gt 0 -and $_.DayOfWeek -lt 6} |
  11.   Measure-Object |
  12.   Select-Object -ExpandProperty Count
  13. "Workdays: $workdays"
复制代码

作者: victorwoo    时间: 2014-7-12 22:45

我知道。
既然是搞脚本的,就应该用脚本来解决。
近期在做博客改版,下一阶段写一些脚本来做这些事情。
作者: victorwoo    时间: 2014-7-18 12:00

回复 3# Batcher

搞好了,请看效果:
http://bathome.net/viewthread.php?tid=31029

源代码在这里:
https://gitcafe.com/victorwoo/vi ... er/util/Get-Ubb.ps1
https://gitcafe.com/victorwoo/vi ... ster/util/Blog.psm1




欢迎光临 批处理之家 (http://bbs.bathome.net/) Powered by Discuz! 7.2