Ежедневник IT-ка
133 subscribers
24 photos
4 videos
1 file
43 links
Программируем на практике!!
По вопросам по поводу проектов: @vladimir_dzen
Download Telegram
2. Открываем в терминале.
3. Запускаем команду в терминале PowerShell:
dotnet publish -c Release --self-contained -p:PublishSingleFile=true
4. В конф. проекта добавляем эту строку:
<RuntimeIdentifier>win-x64</RuntimeIdentifier>
Она необходима для того, чтобы программа запускалась на всех операц. системах Windows.
Подробнее можно посмотреть по ссылке.

 #CSharp, #WPF
Сегодня коснусь SQL запроса.
Очень часто необходимо взять данные с двух табл., которые имеют один(минимум) общий столбец с одинаковыми значениями(это условие Обязательно).

Цель: 
Сделать запрос, который выберет название товаров и артикулов из 2-х разных таблиц согласно названия города и категории , в которых совпадает sku(id) товаров.
1. Таблицы для анализа, для которых и создаётся SQL запрос.
2. Содержание 1 табл.: 'olx_sales_week_by_wh'
3. Содержание 2 табл.: 'products'
4. Запрос и результат:

SELECT olx_sales_week_by_wh.sku,products.articul,products.name
FROM olx_sales_week_by_wh
 LEFT JOIN products ON olx_sales_week_by_wh.sku = products.sku2
WHERE olx_sales_week_by_wh.name ='Львов'
 AND products.category = 'кдх2б' GROUP BY olx_sales_week_by_wh.sku

Получили название товаров и артикулов, где sku(из 1-ой табл.) = sku2(из 2-ой табл.).

Внимание(важная часть запроса, без которой он просто бесполезен): LEFT JOIN products ON olx_sales_week_by_wh.sku = products.sku2

#Sql, #MySql
Хочу сегодня добавить несколько сниппетов по LINQ запросам:

1. Поиск текста по регулярке, множество совпадений в список:

Regex regexJson = new Regex(@"[a-zA-Z0-9]{20,}.*?}");

List<string> tmpList = regexJson.Matches(result).Cast<Match>().Select(m => m.Value).ToList();

List<string> resultsList = tmpList.Where(s => s.Contains("index") && s.Contains("id") && s.Contains("brandId") && !s.Contains("Отзывы") && !s.Contains("advert")).ToList();

2. Создать список ID(индексы строк), в которых содержатся необходимый ключ(особенность: создание анонимного типа с свойствами(Index и Value)):

tmpList.Select((v, i) => new { Index = i, Value = v })
            .Where(p => p.Value.Contains("brandId")).Select(p => p.Index.ToString()).ToList();

3. Получение суммы из списка, которые имеет тип данных string(List<string>) т.е. необходимо значения string сконвертировать в int:

var sumTempResList = tmpResList.Where(d => !string.IsNullOrEmpty(d.Trim())).Select(s => int.Parse(s.Replace("-",""))).ToList().Sum();

4. Создание Dictionary<string,string> из двух разных Списков(List<string>):

List<string> keysList = new List<string>{"2569746", "9876415", "6957459"};

List<string> valuesList = new List<string>{"val1", "val2", "val3"};

Dictionary<string,string> resDict = keysList.Zip(valuesList, (k, v) => new { k, v }).ToDictionary(x => x.k, x => x.v);

5. Создание списка из двух списков, в которых значения не совпадают(т.е. в одном списке, есть в другом нет и те значения, которых нет в другом списке добавляем в новый третий список):

List<string> artsG = new List<string>{"2569746", "9876415", "6957459", "5947945", "9874647"};

List<string> skues = new List<string>{"2569746", "9876415", "6957459"};

List<string> compR_GBD = artsG.Where(n => !skues.Any(s => s.ToLower() == n.ToLower())).ToList();

Получается новый список "compR_GBD" состоящий из этих двух значений("5947945", "9874647")

#LINQ , #CSharp
Хочу показать пример SQL запроса, который пришлось использовать.

Цель: 
Сделать запрос, который покажет ежедневные суммы расходов на рекламу за "текущий" и "прошлый" месяц, для определенной категории товара.
SELECT date, ROUND(sum(spend),2) spend
FROM `reklama` WHERE category = 'одеяла' AND (MONTH(date) = MONTH(CURRENT_DATE()) OR MONTH(date) = MONTH(CURRENT_DATE() - INTERVAL 1 MONTH))
GROUP BY date
ORDER BY date ASC

В этом запросе играет ключевую роль, функция MONTH() - предназначена для того, чтобы извлекать месяц из даты, как раз то, что нам необходимо.
И конечно, помним о том, чтобы увидеть все даты, необходимо сделать группировку GROUP BY date,без этой функции просто будет показана одна дата(одна строка).

#Sql, #MySql
Есть хорошая программа для просмотра данных в Б.Д. heidisql и хочется использовать её для работы с локальной базой к примеру: (localdb)\MSSQLLocalDB используя SQL Server.

Но, просто подключиться к ней, не так уж и просто, для этого необходимо сделать ряд действий:

1. Узнаём куда подключаемся:
2. Настраиваем heidisql:
​​3. Вопрос. Как получить правильный адрес хоста, чтобы подключиться к Б.Д.?

а). Запускаем "cmd"

б). Вбиваем: sqllocaldb s
где: sqllocaldb - база
s - старт сервера(обязательно)

в). Вбиваем: sqllocaldb i MSSQLLocalDB

выводятся ряд строк, но необходима только одна:

Имя канала экземпляра: np:\\.\pipe\LOCALDB#F8B4165B\tsql\query

Вот это и есть адрес хоста, к которому необходимо подключиться.

#Sql, #MySql
string about = string.Empty;

try
{
1. Делаем проверку на наличия необходимо тега с необходимым содержанием. Если, этого тега нет - то, будет Исключение и Пропуск.
about = ZennoPoster.Parser.ParseByXpath(tab.DomText, "//div", "innerHtml").ToList().Where(s => s == "About").First();

2. Проходим по всем блокам тега 'div', чтобы получить атрибуты outerHtml и innerHtml.
foreach (string about_ in ZennoPoster.Parser.ParseByXpath(tab.DomText, "//div", "outerHtml").ToList())
{
try
{
3. Получаем необходимый блок тега 'div' с innerHtml == "About".
about = ZennoPoster.Parser.ParseByXpath(about_, "//div", "innerHtml").ToList().Where(s => s == "About").First();

4. Получаем необходимый блок тега 'div' , только с outerHtml к примеру: "<div class="biGQs _P fiohW tyUdl uuBRH">About</div>"
(может быть любой другой, у нас нет жёсткой привязки, к атрибуту outerHtml)
about = ZennoPoster.Parser.ParseByXpath(about_, "//div", "outerHtml").ToList().Where(s => s.Contains(">About<")).First();

5. Т.к. необходимый Текст находится в необходимо блоке тега 'span', то его можно получить благодаря регулярному выражению, где Первая Часть регулярного выражения, это Содержания тега 'outerHtml'
about = Regex.Match(tab.DomText, about + ".*?</span>").Value;

6. Чистим от мусора.
about = about.Replace(">About<", "><");
about = Regex.Replace(about, "<.*?>", "");
}catch
{
//
}

}
}catch
{
//
}
Сам код:

string about = string.Empty;

try
{
about = ZennoPoster.Parser.ParseByXpath(tab.DomText, "//div", "innerHtml").ToList().Where(s => s == "About").First();

foreach (string about_ in ZennoPoster.Parser.ParseByXpath(tab.DomText, "//div", "outerHtml").ToList())
{
try
{
about = ZennoPoster.Parser.ParseByXpath(about_, "//div", "innerHtml").ToList().Where(s => s == "About").First();
about = ZennoPoster.Parser.ParseByXpath(about_, "//div", "outerHtml").ToList().Where(s => s.Contains(">About<")).First();
about = Regex.Match(tab.DomText, about + ".*?</span>").Value;
about = about.Replace(">About<", "><");
about = Regex.Replace(about, "<.*?>", "");
}catch
{
//
}

}
}catch
{
//
}

#zennoposter, #парсинг