У нас с месяц-полтора назад начала глючить микроволновка. Ей лет 10, но работала всего лет 5.  При открытии двери иногда мигает или вовсе выключается лампочка, при разогреве пищи иногда отключается мотор стола и гаснет лампочка, останавливается вентилятор, но иногда включается. Позвонил знакомому ремонтёру техники. Он сказал - посмотри там на плате управления конденсаторы, заменить бы.

Заменил все 4 конденсатора, купив в Чип и Дипе. Никакой реакции. Вызвал этого мастера домой. Вася поменял два микровыключателя что детектят закрытие двери, показал мне окалину на контактах - мол вот в этом дело! Микровыключатели приклеил на термоклей, т.к. кусочек корпуса отвалился. Ещё сказал что трансформатор загибается. Включили - ноль внимания, глючит как прежде.  Вася забрал плату управления к себе, они её там "на стенде" потестили - всё работает нормально. Без микроволновки туго, Вася вернул плату и один микровыключатель вернул - родные, говорит, лучше. "Жди пока совсем перестанет работать, пока не понятно что с ней. Может дело в вентиляторе или двигателе стола - я недавно такой менял у одного клиента".

Но свинтил Вася плохо - место под крюки от двери имели специальный установочный люфт, Вася закрутил не в том положении, поэтому дверь немножко снизу стала выпирать. Ну и на контакты это повлияло -  постепенно стало коротить при включении так что вырубались три автомата (включая тот что на площадке) - на  6, 16 и 25 Ампер )). В один день так было три раза подряд и всё, решил покупать новую микроволновку. Выбирал-выбирал, потом подумал что можно попробовать ещё раз мне починить. Но жена сказала что нет, не трать время - покупай.

Купил, привезли до подъезда. Дома распаковал, включил в розетку…. Дверь при нажатии на кнопку не открывается! Брак! Звоню в компанию-продавец, пишу им письма. Ответ один: "Мы всё понимаем, но сервисные центры по указу мэра не работают. Дождитесь конца карантина". Блин! А будет ли конец карантина, что делать? Жить без микроволновки?

Разобрал старую, прочитав в интернете что автоматы вышибает из-за микровыключателей. Увидел что дверь стоит косо - привинтил как правильно, укрепил болтающиеся на жиденьком термоклее (и в том числе из-за этого, как я думаю, коротящие) микровыключатели с помощью модельного пластика (ПКЛ - поликапролактон) . Стала работать как на предыдущем этапе - автоматы не вышибает, но отключается  иногда свет и оба мотора, разогрев при этом не прекращается. Но раз не работает вентилятор то и магнетрон может перегреваться, да и пища разогревается неравномерно.

Стал думать. Нашёл универсальную электрическую схему СВЧ. Прозвонил тестером провода, набросал схемку своей СВЧ, соединил симптомы что лампа мигает и в закрытом и открытом положении дверцы, т.е. дело в вентиляторе быть не может. В некоторых (как в моей) СВЧ привод стола низковольтный, т.е. не 220 В а, скажем, 21В. Чтобы такое напряжение сделать используют обмотку вентилятора как автотрансформатор. Но лампа у меня 220 В, т.е. дело не в вентиляторе точно. Стал смотреть плату управления - на ней три реле: одно на подачу питания на трансформатор магнетрона (№2), одно на управление грилем (№3, у меня СВЧ с грилем, который слабенький и ненужный) и одно реле на управление столом, лампой и вентилятором(№1). И тут стало понятно что дело именно в последнем реле.

Но такого реле у меня не было запасного, вообще ни одного реле не нашёл дома. И тут меня осенило. Воспользуюсь реле от гриля. Благо посадочное место на плате было универсальным.

Но замыкающие контакты у реле гриля уходят наверх для подключения клемм, а у реле 1 уходят сразу на плату. Выпаял реле стола, лампы и вентилятора, впаял на его место реле от гриля, верхние клеммы с помощью проводов припаял к плате, пропустив их сбору от платы. И вуаля - всё работает без единого сбойчика! Ну, кроме гриля)

А новую СВЧ спрятал до конца карантина) может удастся вернуть за неё деньги)

How to install Docker - look at

https://gist.github.com/talon/4191def376c9fecae78815454bfe661c

and foollow step by step.

To run ps1 file start powershell as admin and run

Start-Process powershell -verb runas -ArgumentList "-file fullpathofthescript"

Change fullpathofthescript to path, for example:

Start-Process powershell -verb runas -ArgumentList "-file c:\del\1.ps1"

 

If you see after reboot in Docker Desktop console error like:

An unexpected error occurred: Provider is not capable of the attempted operation (0x80041024).

Try to stop VM and start again, then run Docker Desktop:

Thanks to guys from https://forum.sources.ru/index.php?showtopic=408644&st=0&

Прислали несколько PDF дикого размера, при этом при выписке в InDesign настройки сжатия стояли обычные. Стал разбираться - изменение настроек практически не влияет на размер файла, так и остаётся ~100mb.

Посмотрел внутрь файла и обнаружил кучу текстовой информации, оказалось что это  photoshop document ancestors и они совсем не нужны, а InDesign при выписке их просто копирует один в один.

Выглядят они так:

609 0 obj <</Length 5276838/Subtype/XML/Type/Metadata>>stream

и потом много подобных строк:

<rdf:li>00178AD05005B79BDF94C8572B120B2D</rdf:li>

Если в теле то так:

 

Для удаления этой информации я написал скрипт на Python,  на PDF работает отлично, некоторые PDF сжимались с 180 до 4 мегабайт, а некоторые практически никак - в их картинках нет метаданных.

Вот код:

import re
import sys
droppedFile = sys.argv[1]
out=droppedFile.split('.')[0]+"-new."+droppedFile.split('.')[1]

file=droppedFile
with open(file,mode='rb') as file:
filecontent = file.read()

print(len(filecontent))
content_new = re.sub(b'\d+\s0\sobj.<</Length\s\d+/Subtype/XML/Type/Metadata.*?endobj', b'', filecontent, flags = re.M|re.S )

print (len(content_new))

output_file = open(out,"wb")
output_file.write(content_new)
output_file.close()

Ранее я писал как настроить пересылку смс сообщений в Telegram с помощью приложения для Android и веб-скрипта на PHP, но сейчас задача упростилась в разы и стала доступна без единой строчки кода, установки приложения и наличия сервера. Хотя есть нюанс, о нём ниже.

Итак, если вам нужно получать всякие подтверждающие смски от всевозможных сервисов и получать вы их хотите в telegram, slack или facebook messenger, либо нужно чтобы многие видели сразу, что приходит в смс, то поможет в этом сервис Zadarma.

Самый важный нюанс - вам нужно будет арендовать виртуальный мобильный номер и перерегистрировать на него все сервисы, откуда приходят смс. В случае с банками, то в МодульБанке это делается в личном кабинете, в Тинькофф по телефону\чату, а вот в Альфа Бизнес придётся топать с заявлением в отделение. Но удобство чтения sms в телеграме бесценно. Внимание, доставка СМС с коротких номеров не гарантирована, но от Альфа Банка и множества других номеров СМС приходят. Вот пруф:

Итак, вы регистрируетесь в Zadarma, с которым я знаком более 5 лет и вполне доволен.
После регистрации берёте в аренду московский (120р) мобильный виртуальный номер. Минимальный срок аренды (на 2020 год) - 3 месяца.

 


Подтверждаете свою личность сканом паспорта и фотографией с паспортом и словом zadarma с текущей датой.

"Подключение происходит мгновенно после проверки введенных данных." пишут они, но может пройти несколько часов, пока кто-то посмотрит на фотки.

Далее переходим в ваш профиль, кликая по ФИО справа наверху, проматываем страницу вниз до кнопки "Настроить уведомления"

Далее выбираем, допустим, Telegram

жмём Добавить, копируем команду для бота телеграма, переходим по ссылке к боту Zadarma. Вот пример моего диалога, в конце я отправил со своего мобильного смску на виртуальный, пришла она мгновенно!

Если же надо, чтобы смски могли читать несколько человек в чате, то нужно сначала создать этот чат, потом пригласить туда бота ZadarmaBot и только потом добавить уведомление, то есть команду /add=xxxxx нужно будет ввести уже в групповом чате.

Успехов!

Будут вопросы - пишите!

Многие из нас сталкиваются с нежелательными СМС и звонками с предложением ненужных услуг, в последние годы москвичей и питерцев достают автоинформаторы на который даже не выматериться.

Откуда же эти спаммеры берут наши номера? Самый легальный способ получения номеров - покупка их у операторов различных переводов. Читал историю когда в крупном городе бывшего СССР владельцы сети автоматов по приёму платежей сделали бесплатную, лотерею в которой предлагали поучаствовать каждого клиента, единственное что нужно было сделать - согласиться с офертой и ввести номер своего телефона. Оферту, понятное дело, никто не читал, читали только что можно было выиграть "айфон". Не помню, получил ли кто то этот айфон, но владельцы "лотереи" получили базу с телефонами, причём в оферте было полное согласие на использование номера телефона для любой информации. Но это был "легальный" способ где невнимательные граждане формально давали согласие.

Но я уверен что основным источником телефонов для спаммеров являются доски объявлений по типу Avito, где даже без регистрации номер телефона доступен. Может показаться что он доступен только визуально, но несложное программное обеспечение может распознать телефон с картинки. Такие сервисы по тиу Avito имеют миллионы объявлений и, соответственно, каждый новый пользователь может легко попасть в ротацию спаммеров.

Как же от этого защититься? Полностью - никак, но можно значительно снизить поток информационного мусора. Путей два - фильровать номера звонящих и пишущих, либо не публиковать основной номер телефона.

Первый способ проблематичен - нужно чтобы первый контакт всё-таки состоялся, потом номер заносится в чёрный список, либо используется программа (сервис) для телефона, которая имеет свою базу и блокирует смс или телефоны сама. Но такое ПО тоже имеет свою длинную оферту, свою кем-то пополняемую базу и я подозреваю что ручная фильтрация базы на стороне сервиса не производится и возможно занести в спам-список всех клиентов сервиса номер конкурента, плюс для добавления в базу настоящего спаммера кто-то должен с ним один раз столкнутся.

Второй же способ - не публиковать истинный номер телефона - предотвращает попадание номера в базы изначально. Мегафон предоставляет "второй номер" за 1р в день, звонки и СМС приходят на основной номер, но истинного номера никто не знает, этот "второй номер" можно менять, стоимость как и у подключения -  30 рублей. Но гарантий что новый номер отсутствует в базе никаких. Да и всё равно неудобно - всё приходит на тот же физический телефон.

Неужели всё так плохо и выхода нет?

В интернете полно сервисов аренды или даже бесплатного предоставления общего виртуального мобильного номера для получения смс, но посмотрев на эти сервисы хочется хвататься за голову - один общий номер принимает более 1000 смс для регистраций в соцсетях и прочих сервисах. То есть общий номер для всех - никакой безопасности, любой может восстановить доступ к любому сервису по одной смски из общего номера.

Другое дело это получить свой собственный личный виртуальный номер для смс и звонков, плюс получить бесплатную виртуальную АТС (о том, зачем она нужна, чуть позже).

Сервис Zadarma предоставляет виртуальный мобильный номер за 120р в месяц (плюс 120 единоразово за регистрацию номера). Сообщения на виртуальный номер можно получать на электронную почту, Telegram, Facebook Messenger,Slack,Viber. Получать на почту - самое удобное для фильтрации, просматривать, скажем, почту раз в день - папку для отфильтрованных от робота Zadarma писем, ну а если известно что точно нужно получить прямо сейчас (скажем, при регистрации аккаута где-то), следить за этой папкой пару минут, обычно письма с текстом смс поступают менее чем за минуту, очень удобно.

В случае с Avito можно порекомендовать в объявлении писать "на звонки и смс не отвечаю, пишите личное сообщение", либо "на смс не отвечаю, звоните". И тут нам как раз пригодится бесплатная АТС от Zadarma (за каждую минуту переадресации нужно будет заплатить почти 2 рубля). В АТС настраиваем "голосовое приветствие" и наговариваем "Для соединения со мной нажмите цифру 2", далее делаем настройку что только при нажатии цифры 2 происходит переадресация на ваш настоящий номер. Вуаля, никакой робот-спаммер не знает что нужно нажимать каку-то цифру и АТС не переведёт звонок.

Так что виртуальный номер за 120р в месяц (плюс 2р за каждую переадресованную минуту) - спасение от спаммеров и сокрытие номера от других возможных недоброжелателей. Виртуальный номер всегда можно сменить за те же 120р, только не забывайте тщательно подбирать сам номер при покупке в поисковиках (обязательно и в яндексе и в гугле) на предмет его засвеченности, чтобы точно не купить номер кем-то в базы спаммеров засвеченный. Но даже если засвечен - цифру 2 робот не нажмёт. Хотя от назойливых живых спаммеров это не защитит, но их, слава вселенной, на пару порядков меньше.

Как зарегистрироваться в Zadarma

Перейти по ссылке Zadarma наверху кнопка для регистрации, нужно ввести почту, придумать пароль. Далее подтвердить почту (кликнуть по ссылке в почте).

Как купить номер:


Подтверждаете свою личность сканом паспорта и фотографией с паспортом и словом zadarma с текущей датой, либо через Гос Услуги (быстрее).

"Подключение происходит мгновенно после проверки введенных данных." пишут они, но может пройти несколько часов, пока кто-то посмотрит на фотки.

Далее переходим в ваш профиль, кликая по ФИО справа наверху, проматываем страницу вниз до кнопки "Настроить уведомления"

Далее выбираем, допустим, Telegram

жмём Добавить, копируем команду для бота телеграма, переходим по ссылке к боту Zadarma. Вот пример моего диалога, в конце я отправил со своего мобильного смску на виртуальный, пришла она мгновенно!

Перед поездкой в Тбилиси я посмотрел цены на роуминг у всех операторов России, цены меня не порадовали. Но я звонил в РФ за 2р в менуту. У меня основной номер в Мегафоне, в нём даже с опцией "Весь мир" исходящие стоят 129 р в минуту, скидка только на входящие до 40 минут в день, да и то за 109 р абонентской платы в сутки. А меня интересовали именно исходящие.

Проблему решил известным способом - т.к. у меня есть аккаунт в  zadarma, то я просто купил в Тбилиси симкарту местную и поставил приложение zadarma на телефон. При регистрации аккаунта в этом сервисе требуется подтвердить мобильный и все исходящие привязываются к этому номеру мобильного (Caller ID), то есть все кому я звонил видели мой привычный номер мегафона. В этой статье я описывал как зарегистриоваться в сервисе. Можно также купить виртуальный мобильный номер за 120р в месяц (правда, купить его нужно будет минимум на 3 месяца), настроить на своём обычном мобильном номере безусловную переадресацию на этот виртуальный, а в настройках бесплатной виртуальной АТС  zadarma настроить

Симку лучше взять сразу в аэропорту, в Грузии ими не торгуют на каждом шагу, нужно будет поискать (видел в подземных переходах в киосках), но я брал в офисе оператора Geocell. Взял этого оператора по отзывам о хорошем покрытии.

https://geocell.ge/en

Тариф брал с 4 гб трафика, стоила симка 11 лари, это примерно 275 рублей. 4 гб для звонков через zadarma да привычные мессенджеры более чем достаточно, если поездка на неделю-две. Плюс в Тбилиси полно бесплатного Wi-Fi - в автобусах, метро (на станциях), в кафе.

Кстати, качество связи через WhatsApp как через местный WiFi так и через сотовую связь было сильно хуже, чем звонок через zadarma.

Давно уже написал сборщик статистики по выдаче займов и возврату займов в проекте краудфандинга Модульденьги. На странице ежедневно около 18ч вытягиваются публичные данные платформы и сохраняются на сервере, потом рисуются различные графики.

Вот ссылка 

А вот ссылка на телеграм-чат инвесторов https://t.me/ModulDengiChat

Сходил на 2-дневный хакатон NASA, о котором тут  и тут.

Было любопытно. Ничего путного сделать не удалось, но удалось потрогать данные NASA - выгрузить почти гигабайт данных о выбросе Carbon Monoxide (угарный газ) вот отсюда  и визуально понимая как они должны выглядеть (вот Насовский портал с этими данными - ссылка) построить график падения этой эмиссии в Европе и роста в Азии. Странно что в целом несмотря на рост температуры на Земле, линейный тренд падает. Видать, какие-то другие факторы влияют сильнее, чем угарный газ.

Вот данные по Миру, Европе, Азии.

 

carbon monoxide emissions
carbon monoxide emissions - NASA MERRA2

 

Сами исходные данные визуализируются так:

Красное по центру - это горит Африка вдоль Экватора.

Вообще основная засада при обработке данных Nasa  была в долгом понимании, что же за данные содержатся в доступных файлах. Оказывается, нужно было почитать что-то вроде этой страницы где чётко указано

Longitude: -180.00000000000°E to 179.37500000000°E (576 points, avg. res. 0.625°) Latitude: -90.00000000000°N to 90.00000000000°N (361 points, avg. res. 0.5°)

То есть каждый файл за месяц содержит в себе 361 строку, в которой массив из 576 точек. И это всё нужно пересчитать чтобы правильно рисовать картинку. Пришлось ужать скрин с экрана насовской морды под нужное разрешение, вот что получилось. Красным нарисовал квадраты, в котрых потом считалась динамика эмиссии за доступные годы.

Код обработчика тут:

https://github.com/avtomatron/carbon-monoxide

 

Вывод по проделанной работе - Азия задыхается, т.к. Европа вынесла туда вредные производства ))). Шутка. Думаю, Европа перешла на экологичные энергосберегающие технологии, перестала сжигать уголь. А Азия наростила вредные производства - Азиатские тигры развернули свои заводы и т.п.

В целом про хакатоны - ходить полезно, пилить абы что вредно, но нужно делать то, что умеешь.

Бывает что видео на телефон снято при неправильном угле, либо датчик заглючил и всё видео снял с переворотом на 180 градусов.

Поможет повернуть видео бесплатная (opensource)  программа FFMPEG

Совершенно не нужно пугаться что она консольная, то есть нужно будет запустить её через командную строку.

Когда вы скачали программу и распаковали архив, заходите в папку BIN и в неё же копируете ваше видео. В моём случае это было так.

Далее нужно создать файл управления программой. Запускаем Блокнот и пишем там

ffmpeg -i splitpdf.mov -vf "transpose=1" out.mov

вместо единички после знака равно нужно поставить цифру, определяющую поворот

0 = 90 градусов против часовой стрелки и вертикальное отражение
1 = 90 градусов по часовой стрелке
2 = 90 против часовой стрелки
3 = 90 по часовой стрелке и вертикальное отражение

для поворота на 180 градусов

ffmpeg -i splitpdf.mov -vf "transpose=2,transpose=2" out.mov

где splitpdf.mov  вы заменяете на свой файл, не забываете что расширение нужно повторить, т.е. если у вас был mp4 то и out.mp4 нужно прописать.

Вот как выглядит в блокноте:

Далее (внимание!) сохраняем файл в ту же папку, где лежит видео. Расширение у файла должно быть bat

В итоге папка выглядит так:

Запускаем (кликаем дважды) на start.bat

И видим процесс, который продлится долго на слабом ПК и тяжёлом видео. В моём случае поворот происходил на скорости, в два раза превышавшей время проигрывания, то есть минутное видео поворачивалось за 30 секунд.

 

По завершению вы увидите рядом с исходным файлом файл out с повёрнутым видео.

Пишите вопросы, если что-то не получится!

Нередко бывает нужно записать видео инструкцию с экрана. Для Windows я использую исключительно бесплатную (opensource) программу Open Broadcaster Software . Это удобное в работе ПО, в котором поддерживается и русский язык.

Основное окно выглядит так

После установки нужно добавить сцену, а в в сцене уже источник - либо окно, либо экран. Если выбрать окно, то в начале записи программа попросит выбрать окно, которое будет записываться.

Далее необходимо проверить в настройках какой выбран кодек и какое разрешение записи. Я рекомендую x264, для звука битрей 96 и канал Стерео, если вы будете в том числе записывать звуки с компьютера.

 

Перед началом записи необходимо включить или отключить микрофон или звуки ПК. Делается это бегунком, просто тыкаете на желаемый уровень громкости. В примере ниже микрофон будет записываться на полную громкость, а звуки ПК на 3/4 громкости.

 

Вот  и всё, начинайте записывать с экрана сегодня! 🙂