Примечание редактора:
Этот вопрос имеет сложную историю, но сводится к следующему:
* Чтобы узнать, как перечислить записи хэш-таблицы по ее парам ключ-значение, см. принятый ответ.
* Чтобы узнать, как фильтровать хэш-таблицу с помощью набора ключевых значений, см. другой ответ.
Я думаю, что снова попал в проблему X Y, мой первоначальный вопрос касался фильтрации хэш-таблицы. Я обнаружил, что проще фильтровать до создания хеш-таблицы. Ответ на вопрос, верно?
Нет, проблема Y заключалась в циклизации каждого ключа и использовании значений, которые мне помог @briantist.
Моя цель - перебрать имена ключей, которые являются отметками времени, и запланировать задачу с использованием имени ключа в качестве имени задачи и триггера.
Я создаю хэш-таблицу из файла CSV с помощью Group-Object -AsHashTable -AsString
-edit, стоит упомянуть здесь, что фильтрация CSV до создания HashTable упрощает работу с Pipeline
или script.
В качестве примера:
Import-CSV (ls -path D:\ -Filter source*.csv | sort LastWriteTime | Select -Last 1).FullName |
where {$_.TimeCorrected -ne 'ManualRebootServer'} |
group TimeCorrected -AsHashTable -AsString
Я пытаюсь перебрать имена ключей и отобразить имена ключей, используя:
$var = Import-Csv csv123.csv | Group-Object Value1 -AsHashTable -AsString
foreach ($key in $var.Keys){"The key name is $key"}
#Create a scheduled task named and triggered based on the HashTable keyname
#test test test
foreach ($key in $var.keys){IF($key -ne 'ManualRebootServer'){"Register-ScheduledJob"}}
Я просто не уверен, как получить значения из интересующих меня ключей.
Я нашел следующие работы, но только когда я вводил имя ключа вручную. Я просто не знаю, как объединить оба цикла.
($val.GetEnumerator() | Where {$_.key -eq '06-11-16 18:00'} | ForEach-Object { $_.value }).Server