Скрипт импорта Тнв теперь может импортировтаь данные по территории

This commit is contained in:
Антон Чичков 2016-08-19 17:58:30 +10:00
parent 789a13c196
commit 333a1a9436

View File

@ -1,405 +1,446 @@
 
######################################################################## # Параметры командной строки
# Настройки
######################################################################## param (
[Parameter(Mandatory=$true) ][string]$cityName,
# путь к фреймворку ЛЭРС УЧЕТ [Parameter(Mandatory=$false)][string]$dateFromTo,
$LersFrameworkPath = "C:\Program Files\LERS\Common\Framework\bin\Lers.System.dll" [Parameter(Mandatory=$false)][string]$territoryName
)
# Адрес сервера приложения
$ServerAddress = 'localhost' ########################################################################
# Настройки
# Порт сервера приложения ########################################################################
$ServerPort = 10000
# путь к фреймворку ЛЭРС УЧЕТ
# Имя входа/пароль для подключения к Серверу $LersFrameworkPath = "C:\Program Files\LERS\Common\Framework\bin\Lers.System.dll"
$Login = 'login'
$PassWord = 'password' # Адрес сервера приложения
$ServerAddress = 'localhost'
# адрес ресурса
$url = 'http://www.pogoda.ru.net/monitor.php' # Порт сервера приложения
$ServerPort = 10000
# регулярное выражение, для нахождения url адреса заданного города
# <a href="monitor.php?id=35229">Хабаровск</a> # Имя входа/пароль для подключения к Серверу
$regExpressionCityFirst = '(?i:<a\shref="(.+)">' $Login = 'login'
$regExpressionCitySecond = '</a>)' $PassWord = 'password'
# регулярное выражение для поиска среднесуточной температуры # адрес ресурса
# <th class=black>5</th><td class=blue1>-21.0</td><td class=green>-15.1</td> $url = 'http://www.pogodaiklimat.ru/monitor.php'
$regExpressionTemperatureFirst = '(?i:<th\sclass=black>'
$regExpressionTemperatureSecond = '</th>\s*<td\sclass=\w+>[\d\.\-\+]+</td>\s*<td\sclass=\w+>([\d\.\-\+]+)</td>)' # регулярное выражение, для нахождения url адреса заданного города
# <a href="monitor.php?id=35229">Хабаровск</a>
################################################################## $regExpressionCityFirst = '(?i:<a\shref="(.+)">'
# Подключаемые типы $regExpressionCitySecond = '</a>)'
##################################################################
# регулярное выражение для поиска среднесуточной температуры
try # <th class=black>5</th><td class=blue1>-21.0</td><td class=green>-15.1</td>
{ $regExpressionTemperatureFirst = '(?i:<th\sclass=black>'
# подключаем фреймворк $regExpressionTemperatureSecond = '</th>\s*<td\sclass=\w+>[\d\.\-\+]+</td>\s*<td\sclass=\w+>([\d\.\-\+]+)</td>)'
add-type -path $LersFrameworkPath
} ##################################################################
catch # Подключаемые типы
{ ##################################################################
write-host 'Ошибка. Не удалось загрузить файл Lers.System.dll. Проверьте правильность расположения файла. ' + $Error[0].Exception.Message
exit try
} {
# подключаем фреймворк
######################################################################## add-type -path $LersFrameworkPath
# Функции }
######################################################################## catch
{
# Проверяет заданы ли параметры настройки скрипта write-host 'Ошибка. Не удалось загрузить файл Lers.System.dll. Проверьте правильность расположения файла. ' + $Error[0].Exception.Message
Function CheckParameters($url, $ServerAddress, $ServerPort, $Login, $PassWord) exit
{ }
try
{ ########################################################################
if ($url -eq '') # Функции
{ ########################################################################
throw new-object Exception('Адрес сайта мониторинга погоды не задан.')
} # возвращает содержимое html страницы по адресу url ввиде строки
Function Get-WwwString([string]$url, [string]$Encoding = "windows-1251")
if ($ServerAddress -eq '') {
{ try
throw new-object Exception('Адрес сервера ЛЭРС УЧЕТ не задан.') {
} # создаем web client
$wc = new-object System.Net.WebClient
if (($ServerPort -eq $null) -or ($ServerPort -eq 0) -or ($ServerPort -eq ''))
{ # устанавливаем кодировку
throw new-object Exception('Порт сервера ЛЭРС УЧЕТ не задан.') $wc.Encoding = [System.Text.Encoding]::GetEncoding($Encoding)
}
# возвращаем html страницу ввиде строки
if ($Login -eq '') return $wc.DownloadString($url)
{ }
throw new-object Exception('Имя входа в ЛЭРС УЧЕТ не задано.') catch
} {
throw new-object Exception('Не удалось загрузить html страницу по адресу ' + $url + '.', $Error[0].Exception)
if ($PassWord -eq '') }
{ }
throw new-object Exception('Пароль для входа в ЛЭРС УЧЕТ не задан.')
} #>
}
catch
{
throw new-object Exception('Параметры скрипта не настроены. ', $Error[0].Exception) ################################################################
} # возвращает url адрес на страницу заданного города
} # $reply - содержимое html страницы ввиде строки
# $gorod - имя города
################################################################## # $url - адрес страницы мониторинга погоды
################################################################
# возвращает содержимое html страницы по адресу url ввиде строки Function Get-CityUrl($reply, $gorod, $url)
Function Get-WwwString([string]$url, [string]$Encoding = "windows-1251") {
{ try
try {
{ # регулярное выражение, для нахождения url адреса заданного города
# создаем web client # <a href="monitor.php?id=35229">Хабаровск</a>
$wc = new-object System.Net.WebClient [regex]$reg = $regExpressionCityFirst + $gorod + $regExpressionCitySecond
$match = $reg.match($reply)
# устанавливаем кодировку
$wc.Encoding = [System.Text.Encoding]::GetEncoding($Encoding) if(!$match.Success)
{
# возвращаем html страницу ввиде строки throw new-object Exception(' Url страницы не найден.')
return $wc.DownloadString($url) }
}
catch # формируем ссылку на страницу
{ $uri = new-object Uri ($url)
throw new-object Exception('Не удалось загрузить html страницу по адресу ' + $url + '.', $Error[0].Exception) $urlCity = $match.Groups[1].value
} $urlCity = 'http://' + $uri.Host + '/' + $urlCity
}
return $urlCity
################################################################## }
catch
# возращает описание исключений {
Function GetFullExceptionMessage([Exception]$exc) throw new-object Exception('Не удалось получить ссылку на страницу города - ' + $gorod + '.', $Error[0].Exception)
{ }
if($exc -eq $null) }
{
return ''
} ################################################################
# возвращает хеш-таблицу среднесуточной температуры наружного воздуха за указанный период времени
$msg = $exc.Message # dateFrom - дата начало периода
# dateTo - дата окончания периода
if ($exc.InnerException -ne $null) # link - url города
{ ################################################################
$mes = GetFullExceptionMessage $exc.InnerException Function Get-CityTemperature($dateFrom, $dateTo, $link)
$msg = $msg + ' ' + $mes {
} try
{
return $msg $today = [DateTime]::Today
} if($dateFrom -gt $today)
{
########################################################################## throw new-object Exception('Дата начала периода превышает текущую.')
}
# возвращает url адрес на страницу заданного города
# $reply - содержимое html страницы ввиде строки if($dateFrom -gt $dateTo)
# $gorod - имя города {
# $url - адрес страницы мониторинга погоды throw new-object Exception('Дата начала периода больше даты окончания.')
Function Get-CityUrl($reply, $gorod, $url) }
{
try if($dateTo -gt $today)
{ {
# регулярное выражение, для нахождения url адреса заданного города $dateTo = $today
# <a href="monitor.php?id=35229">Хабаровск</a> }
[regex]$reg = $regExpressionCityFirst + $gorod + $regExpressionCitySecond
$match = $reg.match($reply) # хеш таблица для хранения среднесуточных значениий температур по дате
$TempTable = @{}
if(!$match.Success)
{ # месяц, за который загружается html-страница с темпераиурами
throw new-object Exception(' Url страницы не найден.') $month = 0
}
# html страница
# формируем ссылку на страницу [void][string]$html
$uri = new-object Uri ($url)
$urlCity = $match.Groups[1].value while ($dateFrom -le $dateTo)
$urlCity = 'http://' + $uri.Host + '/' + $urlCity {
if ($dateFrom.Month -ne $month)
return $urlCity {
} $month = $dateFrom.Month
catch
{ # ссылка на страницу за указанный месяц и год
throw new-object Exception('Не удалось получить ссылку на страницу города - ' + $gorod + '.', $Error[0].Exception) $ref = $link + '&month=' + $dateFrom.Month + '&year=' + $dateFrom.Year
}
} Write-Host $ref
# загружаем html страницу заданного месяца и года
########################################################################## $html = Get-WwwString $ref
}
# возвращает хеш-таблицу среднесуточной температуры наружного воздуха за указанный период времени
# dateFrom - дата начало периода # регулярное выражение для поиска среднесуточной температуры
# dateTo - дата окончания периода # <th class=black>5</th><td class=blue1>-21.0</td><td class=green>-15.1</td>
# link - url города [regex]$reg = $regExpressionTemperatureFirst + $dateFrom.Day + $regExpressionTemperatureSecond
Function Get-CityTemperature($dateFrom, $dateTo, $link) $match = $reg.match($html)
{
try if (!$match.Success)
{ {
$today = [DateTime]::Today # температура не найдена
if($dateFrom -gt $today) throw new-object Exception('Температура не найдена.')
{ }
throw new-object Exception('Дата начала периода превышает текущую.')
} # считываем температуру
$T = $match.Groups[1].value
if($dateFrom -gt $dateTo)
{ # сохраняем температуру
throw new-object Exception('Дата начала периода больше даты окончания.') $TempTable[$dateFrom.ToString()] = $T
}
$dateFrom = $dateFrom.AddDays(1)
if($dateTo -gt $today) }
{
$dateTo = $today return $TempTable
} }
catch
# хеш таблица для хранения среднесуточных значениий температур по дате {
$TempTable = @{} throw new-object Exception('Ошибка получения среднесуточной температуры за указанный период. ', $Error[0].Exception)
}
# месяц, за который загружается html-страница с темпераиурами }
$month = 0
# html страница
[void][string]$html ################################################################
# Функция подключается к серверу и возвращает объект сервера
while ($dateFrom -le $dateTo) ################################################################
{ Function ConnectToServer()
if ($dateFrom.Month -ne $month) {
{ try
$month = $dateFrom.Month {
Write-Host 'подключаемся к серверу по адресу ' $ServerAddress ':' $ServerPort
# ссылка на страницу за указанный месяц и год
$ref = $link + '&month=' + $dateFrom.Month + '&year=' + $dateFrom.Year $securePassword = [Lers.Networking.SecureStringHelper]::ConvertToSecureString($PassWord)
# загружаем html страницу заданного месяца и года $authenticationInfo = New-Object Lers.Networking.BasicAuthenticationInfo($Login, $securePassword)
$html = Get-WwwString $ref
} # подключаемся к серверу
$server = new-object Lers.LersServer
# регулярное выражение для поиска среднесуточной температуры
# <th class=black>5</th><td class=blue1>-21.0</td><td class=green>-15.1</td> $server.Connect($ServerAddress, $ServerPort, $authenticationInfo)
[regex]$reg = $regExpressionTemperatureFirst + $dateFrom.Day + $regExpressionTemperatureSecond return $server
$match = $reg.match($html) }
catch
if (!$match.Success) {
{ throw new-object Exception('Не удалось подключится к серверу ЛЭРС УЧЕТ. ', $Error[0].Exception)
# температура не найдена }
throw new-object Exception('Температура не найдена.') }
}
# считываем температуру ################################################################
$T = $match.Groups[1].value # функция сохраняет данные о температуре на сервере ЛЭРС УЧЕТ
# $server - сервер автоматизации
# сохраняем температуру # $tempTable - таблица среднесуточных температур
$TempTable[$dateFrom.ToString()] = $T ################################################################
Function SaveTemperatureToServer ($server, $territory, $tempTable)
$dateFrom = $dateFrom.AddDays(1) {
} Write-Host 'Cохраняем данные на сервере ЛЭРС УЧЕТ'
try
return $TempTable {
} $str =''
catch $keys = $tempTable.Keys
{
throw new-object Exception('Ошибка получения среднесуточной температуры за указанный период. ', $Error[0].Exception) $temperature = New-Object Lers.Data.OutdoorTemperatureRecord[] $keys.Count
} $i = 0
}
foreach($key in $keys)
########################################################################## {
$dt = [DateTime]::Parse($key)
# возвращает входные параметры
Function Arguments($inArgs) $value = [string]$tempTable[$key]
{
try $separator = [System.Globalization.CultureInfo]::CurrentCulture.NumberFormat.NumberDecimalSeparator;
{
# проверяем количество параметров $value = [Convert]::ToSingle($value.Replace(".",$separator))
if($inArgs.Length -eq 0) $record = New-Object Lers.Data.OutdoorTemperatureRecord($dt, $territory)
{
throw new-object Exception('Отсутствуют параметры командной строки.') $record.Value = $value
}
$temperature[$i] = $record
# возвращает введенное имя города
$gorod = $inArgs[0] $i++
$gorod }
[DateTime]$dateTo = [System.DateTime]::Today.AddDays(-1) # сохранение данных на сервере
[DateTime]$dateFrom = $dateTo $server.OutdoorTemperature.Set($temperature)
}
catch
if($inArgs.Length -eq 2) {
{ throw new-object Exception('Не удалось сохранить данные среднесуточной температуры на сервере ЛЭРС учет. ', $Error[0].Exception)
$DateTimeStr = $inArgs[1] }
$DateTimeStr = $DateTimeStr.Split('-', [System.StringSplitOptions]::RemoveEmptyEntries) }#>
if($DateTimeStr.Length -ne 2) #################################################
{ # Возвращает территорию, в котороую будет сохраняться температура
throw new-object Exception('Период времени задан неверно.') #################################################
} Function GetTerritory($server)
{
# дата начало периода if ($territoryName -eq "")
if (![DateTime]::TryParse($DateTimeStr[0], [ref]$dateFrom)) {
{ $server.Territories.DefaultTerritory
throw new-object Exception('Дата начала периода задана в неверном формате. Формат даты: dd.mm.yyyy') }
} else
{
$territoryList = $server.Territories.GetList()
# дата конца периода
if (![DateTime]::TryParse($DateTimeStr[1], [ref]$dateTo)) foreach ($territory in $territoryList)
{ {
throw new-object Exception('Дата окончания периода задана в неверном формате. Формат даты: dd.mm.yyyy') if ($territory.Name -eq $territoryName)
} {
} $territory
return
}
}
throw new-object Exception("На сервере не найдена территория $territoryName")
}
}
#################################################
# Возвращает входные параметры
#################################################
Function GetFromToDate($inArgs)
{
try
{
[DateTime]$dateTo = [System.DateTime]::Today.AddDays(-1)
[DateTime]$dateFrom = $dateTo
if ($dateFromTo -ne "")
{
$dateFromTo = $dateFromTo.Split('-', [System.StringSplitOptions]::RemoveEmptyEntries)
if($dateFromTo.Length -ne 2)
{
throw new-object Exception('Период времени задан неверно.')
}
# дата начало периода
if (![DateTime]::TryParse($dateFromTo[0], [ref]$dateFrom))
{
throw new-object Exception('Дата начала периода задана в неверном формате. Формат даты: dd.mm.yyyy')
}
# дата конца периода
if (![DateTime]::TryParse($dateFromTo[1], [ref]$dateTo))
{
throw new-object Exception('Дата окончания периода задана в неверном формате. Формат даты: dd.mm.yyyy')
}
}
# возвращаем дату начало/конца
$dateFrom
$dateTo
}
catch
{
throw new-object Exception('Ошибка разбора параметров коммандной строки. ', $Error[0].Exception)
}
}
#################################################
# Проверяет заданы ли параметры настройки скрипта
#################################################
Function CheckParameters($url, $ServerAddress, $ServerPort, $Login, $PassWord)
{
try
{
if ($url -eq '')
{
throw new-object Exception('Адрес сайта мониторинга погоды не задан.')
}
if ($ServerAddress -eq '')
{
throw new-object Exception('Адрес сервера ЛЭРС УЧЕТ не задан.')
}
if (($ServerPort -eq $null) -or ($ServerPort -eq 0) -or ($ServerPort -eq ''))
{
throw new-object Exception('Порт сервера ЛЭРС УЧЕТ не задан.')
}
if ($Login -eq '')
{
throw new-object Exception('Имя входа в ЛЭРС УЧЕТ не задано.')
}
if ($PassWord -eq '')
{
throw new-object Exception('Пароль для входа в ЛЭРС УЧЕТ не задан.')
}
}
catch
{
throw new-object Exception('Параметры скрипта не настроены. ', $Error[0].Exception)
}
}
#################################################
# возращает описание исключений
#################################################
Function GetFullExceptionMessage([Exception]$exc)
{
if($exc -eq $null)
{
return ''
}
$msg = $exc.Message
if ($exc.InnerException -ne $null)
{
$mes = GetFullExceptionMessage $exc.InnerException
$msg = $msg + ' ' + $mes
}
return $msg
}
##########################################################################
# Точка входа
##########################################################################
try
{
Write-Host 'Запуск импорта данных среднесуточной температуры с сайта мониторинга погоды.'
# проверяем параметры настройки скрипта
CheckParameters $url $ServerAddress $ServerPort $Login $PassWord
#param[0] = город, param[1] = дата_начала, param[2] = дата_окончания, param[3] = территория
[object[]]$param = GetFromToDate
Write-host 'Загружаем ресурс ' $url
# загружаем html страницу
$reply = Get-WwwString $url
# получаем ссылку на страницу, указанного города
$link = Get-CityUrl $reply $cityName $url
# загружаем таблицу с температурами наружного воздуха
Write-Host $param[0]
Write-Host $param[1]
Write-host $link
$tempTable = Get-CityTemperature $param[0] $param[1] $link
write-host 'Получены среднесуточные температуры.'
# подключаемся к серверу ЛЭРС
$server = ConnectToServer
$territory = GetTerritory $server
# возвращаем дату начало/конца # сохраняем температуру на сервере
$dateFrom SaveTemperatureToServer $server $territory $tempTable
$dateTo
} Write-Host 'Импорт температур успешно завершен.'
catch }
{ catch
throw new-object Exception('Ошибка разбора параметров коммандной строки. ', $Error[0].Exception) {
} write-host 'Ошибка импорта температур. ' (GetFullExceptionMessage $Error[0].Exception)
} exit
}
##########################################################################
# Функция подключается к серверу автоматизации и возвращает объект сервера
Function ConnectToServer()
{
try
{
Write-Host 'подключаемся к серверу по адресу ' $ServerAddress ':' $ServerPort
$securePassword = [Lers.Networking.SecureStringHelper]::ConvertToSecureString($PassWord)
$authenticationInfo = New-Object Lers.Networking.BasicAuthenticationInfo($Login, $securePassword)
# подключаемся к серверу
$server = new-object Lers.LersServer
$server.Connect($ServerAddress, $ServerPort, $authenticationInfo)
return $server
}
catch
{
throw new-object Exception('Не удалось подключится к серверу ЛЭРС УЧЕТ. ', $Error[0].Exception)
}
}
##########################################################################
# функция сохраняет данные о температуре на сервере ЛЭРС УЧЕТ
# $server - сервер автоматизации
# $tempTable - таблица среднесуточных температур
Function SaveTemperatureToServer ($server, $tempTable)
{
Write-Host 'Cохраняем данные на сервере ЛЭРС УЧЕТ'
try
{
$str =''
$keys = $tempTable.Keys
$temperature = New-Object Lers.Data.OutdoorTemperatureRecord[] $keys.Count
$i = 0
foreach($key in $keys)
{
$dt = [DateTime]::Parse($key)
$value = [string]$tempTable[$key]
$separator = [System.Globalization.CultureInfo]::CurrentCulture.NumberFormat.NumberDecimalSeparator;
$value = [Convert]::ToSingle($value.Replace(".",$separator))
$record = New-Object Lers.Data.OutdoorTemperatureRecord($dt)
$record.Value = $value
$temperature[$i] = $record
$i++
}
# сохранение данных на сервере
$server.OutdoorTemperature.Set($temperature)
}
catch
{
throw new-object Exception('Не удалось сохранить данные среднесуточной температуры на сервере ЛЭРС учет. ', $Error[0].Exception)
}
}
##########################################################################
# Точка входа
##########################################################################
try
{
Write-Host 'Запуск импорта данных среднесуточной температуры с сайта мониторинга погоды.'
# проверяем параметры настройки скрипта
CheckParameters $url $ServerAddress $ServerPort $Login $PassWord
#param[0] = город, param[1] = дата_начала, param[2] = дата_окончания
[object[]]$param = Arguments $Args
Write-host 'Загружаем ресурс ' $url
# загружаем html страницу
$reply = Get-WwwString $url
# получаем ссылку на страницу, указанного города
$link = Get-CityUrl $reply $param[0] $url
# загружаем таблицу с температурами наружного воздуха
$tempTable = Get-CityTemperature $param[1] $param[2] $link
write-host 'Получены среднесуточные температуры.'
# подключаемся к серверу ЛЭРС
$server = ConnectToServer
# сохраняем температуру на сервере
SaveTemperatureToServer $server $tempTable
Write-Host 'Импорт температур успешно завершен.'
}
catch
{
write-host 'Ошибка импорта температур. ' (GetFullExceptionMessage $Error[0].Exception)
exit
}
########################################################################