-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathlesson4.ps1
144 lines (107 loc) · 7.4 KB
/
lesson4.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
# Работа с файловой системой
#
# 4.1 Работа с файловой системой
#
pwd # отобразит полный путь к текущей директории
(pwd).Path # "C:\Users\oleg.ivanov" чтобы получить только путь в виде строки
# работает только в скрипте, на тот случай запускаете скрипт находясь в другой папке
$currentDirectory = $MyInvocation.MyCommand.Definition | split-path -parent
$currentDirectory
Test-Path $currentDirectory # True, проверка существует ли заданный путь
Get-ChildItem # отобразит список файлов и папок в текущей директории (gci, ls, dir синонимы)
Get-ChildItem -Path "c:\" # отобразит элементы по указанному пути
Get-ChildItem -Path "c:\" -Force # отобразит элементы по указанному пути включая скрытые файлы
Get-ChildItem -Recurse # отобразит список всех файлов и папок в текущей директории включая вложенные
Get-ChildItem -Path "d:\*.txt" -Force # отобразить список файлов с рамширением *.txt
# все исполняемые файлы старше 2014-04-01
Get-ChildItem -Path "C:\Program Files" -Recurse -Include *.exe | Where-Object {($_.LastWriteTime -gt "2014-04-01")}
Copy-Item "d:\test.txt" "d:\test1.txt" # копирует элемент, первым задается путь к элементу, затем путь назначения
Copy-Item "d:\files\*" "d:\Backups\" # скопировать содержимое директории в другую директорию (без рекурсии)
Copy-Item "d:\files\*" "d:\Backups\" -Recurse # скопировать содержимое директории в другую директорию (c рекурсией)
New-Item "C:\Users\oleg.ivanov\file.txt" -ItemType File # Создать новый пустой файл
New-Item "C:\Users\oleg.ivanov\directory" -ItemType Directory # Создать новую директорию
New-Item "C:\Users\oleg.ivanov\file.txt" -ItemType File -Force # Создать новый пустой файл (перезаписать если существует)
Remove-Item "C:\Users\oleg.ivanov\file.txt" # удалит элемент по указанному пути (безвозвратно, не перемещает в корзину)
Remove-Item "C:\Users\oleg.ivanov\directory" -Force # удалит элемент по указанному пути (-Force для принудительного удаления не пустой папки)
Remove-Item "d:\test\*" -Include *.txt -Exclude *test* # удалит все текстовые файлы в папке, кроме тех, в названии которых есть "test"
Rename-Item "d:\test.txt" "test5.txt" # переименует указанный объект
#
# 4.2 Работа с содержимым файлов
#
Get-Content "D:\questions.txt" # получить содержимое файла в массив, каждую строку как отдельный элемент
(Get-Content "D:\questions.txt") -join "`n" # преобразовать содержимое файла в строку
Set-Content D:\newitemtest.txt "This is the test content" # перезапишет содержимое файла
Add-Content D:\newitemtest.txt "This is the best content" # добавит строку в конец файла
Get-ChildItem > D:\newitemtest.txt # перенаправит результат выполнения комманды в файл (перезапишет)
Get-ChildItem >> D:\newitemtest.txt # перенаправит результат выполнения комманды в файл (добавит в конец файла)
Get-ChildItem | ConvertTo-Html # преобразовать результат комманды в html код
Get-ChildItem | ConvertTo-Xml
Get-ChildItem | ConvertTo-Csv
Get-ChildItem | ConvertTo-Json -Depth 5 # преобразовать результат комманды в json (-Depth указывает на глубину объекта)
$data = @{
"first" = @{
"second" = @{
"third" = @{
"fourth" = "test"
}
}
}
} | ConvertTo-Json -Depth 5
#
# 4.3 Работа с xml
#
[xml]$config = Get-Content .\config.xml # загрузить содержимое файла как xml
$config.xml.Section.BEName # отобразить содержимое элемента
$config.xml.Section.BEName | Where { $_.Status -eq 1 } # отобразить элементы, с полем "Status" равным 1
#
# 4.4 Работа с Json
#
$config = Get-Content -Raw -Path .\config.json | ConvertFrom-Json # загрузить содержимое файла как объект
$config
$config.Name # Oleg
# 4.5 Работа с CSV
$users = Import-Csv .\users.csv # импортировать CSV как объект (пользовательский объект, массив из хэшей)
$users
$users[0].FirstName # Oleg
#
# 4.6 Регулярные выражения (язык поиска совпадений в строках и манипуляциях с ними)
#
$output = "We will use the 192.168.0.1 ip address for connection."
$ip = [Regex]::Match($output, "\d+\.\d+\.\d+\.\d+").Value
$ip # 192.168.0.1
<#
[abc] # совпадение по любому из указанных символов
[^abc] # совпадение по любому символу кроме указанных
[a-z] # совпадение по символу из диапазона
. # любой символ
\s # пробел
\S # любой не пробел
\d # цифра
\D # не цифра
\w # буква
\W # не буква
a* # 0 или более вхождений "a"
a+ # одно или более вхождений "a"
a{3} # ровно три вхождения "a"
\. # рассматривать . как точку, а не как любой символ
^ # начало строки
$ # конец строки
#>
$newString = $output -Replace "\d+\.\d+\.\d+\.\d+", "127.0.0.1" # замена вхождения в строке
$newString # "We will use the 127.0.0.1 ip address for connection."
# Как взять определенное вхождение
$output = "We will use the 192.168.0.1 and 127.0.0.1 ip addreses for connection."
$ip = ([Regex]"\d+\.\d+\.\d+\.\d+").Matches($output)
$ip[1].Value # 127.0.0.1
# Очень важно использовать точные регулярные выражения
$output = "https://vmsnapshotdisks690.blob.core.windows.net/vhds/centos120161206144356.vhd"
$accountName = ([Regex]"(\/\/)(\w+)").Matches($output).Groups[2].Value
$accountName
$output = "https://ciscofogfasttrackstorage.blob.core.windows.net/vhds/CSR-disk-mu5zgxrcoqmlo.vhd"
$diskName = [Regex]::Match($output, "\w+\.vhd$").Value
$diskName # mu5zgxrcoqmlo.vhd неточное регулярное выражение
$diskName = $output -replace ".*\/", ""
$diskName
# Домашнее задание
# http://www.osp.ru/winitpro/2013/10/13037712/
# https://regex101.com/