gpt4 book ai didi

powershell - Powershell-每天分配一个变量

转载 作者:行者123 更新时间:2023-12-03 00:40:58 24 4
gpt4 key购买 nike

我有一个简单的脚本,该脚本将变量分配给“昨天”,使用RestAPI根据昨天的日期获取我所在位置的日出和日落时间,然后格式化结果。

$yesDate = (Get-Date).AddDays(-1) | Get-Date -Format "yyyy-MM-dd"
$daylight = (Invoke-RestMethod "https://api.sunrise-sunset.org/json?lat=35.608237&lng=-78.647497&formatted=0&date=$yesDate").results
$sunrise = ($daylight.Sunrise | Get-Date -Format "yyyy-MM-dd HH:mm:ss")
$sunset = ($daylight.Sunset | Get-Date -Format "yyyy-MM-dd HH:mm:ss")
我现在想做的就是更新脚本,使其采用每月的每一天(例如,9月1日至27日(昨天)),获取日出和日落值,然后为它们分配一个变量(例如 $sunrise1$sunset1) 。
关于我什至可以做到这一点的任何想法吗?
更新:
我有一个输入文件,其中每一天的每一分钟都有一行,下面是一些示例行:
2020-09-28 00:00:00 0.0
2020-09-28 00:01:00 0.0
2020-09-28 00:02:00 0.0
2020-09-28 00:03:00 0.0
2020-09-28 00:04:00 0.0
2020-09-28 00:05:00 0.0
我使用上面的原始脚本获取了昨天的日出/日落时间,然后使用下面的脚本删除了日出之前和日落之后的所有行。然后,它完全删除了时间戳,然后取剩余值的平均值,最后格式化平均值。
Get-Content C:\CumulusMX\summaries\Txt_Files\daily_values_uv_unedited.txt | 
Where-Object { $_ -ge $sunrise -and $_ -le $sunset } |
Out-File C:\CumulusMX\summaries\Txt_Files\daily_values_uv_consolidated.txt
(Get-Content C:\CumulusMX\summaries\Txt_Files\daily_values_uv_consolidated.txt) -Replace '\d\d\d\d-\d\d-\d\d \d\d:\d\d:\d\d\t', '' |
Out-File C:\CumulusMX\summaries\Txt_Files\daily_values_uv_no_timestamp.txt
Get-Content C:\CumulusMX\summaries\Txt_Files\daily_values_uv_no_timestamp.txt |
Measure-Object -Average |
Select-Object -ExpandProperty Average |
Out-File C:\CumulusMX\summaries\Txt_Files\daily_values_uv_raw_avg.txt
$result = Get-Content C:\CumulusMX\summaries\Txt_Files\daily_values_uv_raw_avg.txt
[MATH]::Round($result,1) |
Out-File C:\CumulusMX\summaries\Txt_Files\daily_values_uv.txt
这可能不是实现目标的最干净的方法,但出于在一天中获取环境变量,滤除非白天时间并获取平均值的目的,它就可以正常工作。但是,下一个目标是在一个月内(有时是一年)执行相同的功能,但要考虑到日出和日落时间每天都会变化...

最佳答案

您可以采用其他方法,并输出具有SunriseSunset属性的自定义对象的数组。

# Yesterday
$yesdate = (Get-Date).AddDays(-1)

# Loop through day 1 to yesterday
$Times = 1..$yesdate.Day | Foreach-Object {
$currentDate = Get-Date -Day $_ -Month $yesdate.Month -Year $yesdate.Year -Format 'yyyy-MM-dd'
$daylight = (Invoke-RestMethod "https://api.sunrise-sunset.org/json?lat=35.608237&lng=-78.647497&formatted=0&date=$currentDate").results
[pscustomobject]@{
Sunrise = ([datetime]$daylight.Sunrise).ToString('yyyy-MM-dd HH:mm:ss')
Sunset = ([datetime]$daylight.Sunset).ToString('yyyy-MM-dd HH:mm:ss')
}
}
# Outputs sample section

# $Times is an array of objects with sunrise and sunset properties
# $Times one array element for each day starting from day 1 to yesterday of the given month
$Times
# Outputs day 1 sunrise
$Times[0].Sunrise
# Outputs day 10 sunset
$Times[9].Sunset
# Outputs day 15 sunrise and sunset as an object
$Times[14]
# Outputs day 15 sunrise and sunset as comma-separated values
"{0},{1}" -f $Times[14].Sunrise,$Times[14].Sunset
编辑:使用您的示例
如果要检查文件的特定日期,可以执行以下操作:
# Checking day 28

Get-Content C:\CumulusMX\summaries\Txt_Files\daily_values_uv_unedited.txt | Where {
[datetime]($_ -replace '\d+\.\d+') -ge [datetime]$Times[27].Sunrise -and [datetime]($_ -replace '\d+\.\d+') -le [datetime]$Times[27].Sunset
}
您还可以遍历给定月份的所有日子:
$daily = Get-Content C:\CumulusMX\summaries\Txt_Files\daily_values_uv_unedited.txt
foreach ($Time in $Times) {
$Sunset = [datetime]$Time.Sunset
$Sunrise = [datetime]$Time.Sunrise
$daily | Where {
[datetime]($_ -replace '\d+\.\d+') -ge $Sunrise -and [datetime]($_ -replace '\d+\.\d+') -le $Sunset
}
}

关于powershell - Powershell-每天分配一个变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64109530/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com