Mad Devs Channel


Гео и язык канала: Киргизия, Русский
Категория: Технологии


Канал Mad Devs.🤘Здесь мы рассказываем о жизни компании и инсайтах. Делимся знаниями и лайфхаками IT-индустрии.

Связанные каналы

Гео и язык канала
Киргизия, Русский
Категория
Технологии
Статистика
Фильтр публикаций


🎙Покоряем новые форматы: Толя Федоренко на подкасте Llewellan Vance

С гордостью хотим поделиться, что Толя Федоренко, наш Head of Delivery department, недавно принял участие в подкасте Llewellan Vance.

В этом выпуске Толя рассказывает о своем невероятном пути в рамках инициативы Teenagers In Free Enterprise (TIFE), которая предоставляет молодым людям практический опыт ведения бизнеса. Также, он делится своими знаниями о Теории ограничений (TOC) - мощном фреймворке, способном трансформировать управление проектами и корпоративную стратегию. Вас ждут ценнейшие инсайты, начиная с внедрения TOC в стартапах и заканчивая достижением успеха с помощью метода Gold Tree.

Подкаст можно прослушать по ссылке.

Поделитесь, отзываются ли вам мысли Толи? Отметили ли вы для себя что-то особенное?


⚡️Вакансия: В команду @MrCyberSec' rel='nofollow'>Мекана Байриева (Mad Devs Cybersec Lead) ищем талантливого Junior Web Application Security Specialist

👨‍💻Ключевые обязанности:
- Проведение оценки безопасности и тестов на проникновение в веб-приложения с целью выявления уязвимостей.
- Участие в написании отчетов.
- Работа с системой управления проектами Jira.
- Тесное сотрудничество с командами разработчиков для устранения недостатков в системе безопасности.
- Быть в курсе последних тенденций в области безопасности, угроз и мер противодействия.
- Помощь в разработке и внедрении лучших практик и политик безопасности.
- Сотрудничество со старшими специалистами по безопасности в рамках сложных проектов по обеспечению безопасности.

💻 Квалификации:
- Степень бакалавра в области компьютерных наук, информационной безопасности или смежной области, или эквивалентный опыт работы.
- Понимание веб-технологий, языков программирования и сетевых протоколов.
- Знакомство с инструментами и методологиями тестирования безопасности веб-приложений.
- Базовые знания об общих уязвимостях веб-приложений (например, OWASP Top 10).
- Отличные навыки решения проблем и внимание к деталям.
- Сильные коммуникативные навыки, как письменные, так и устные.
- Способность к сотрудничеству в командной среде.

⭐️ Будет плюсом, если есть:
- Опыт работы с языками программирования (например, Python, JavaScript).
- Рейтинг на площадках HackTheBox, TryHackme и пр
- Пройденные курсы в академии PortSwigger, HackTheBox, Codeby и пр
- Любые сертификаты, такие как CompTIA Security+, CEH, и тд.

✍️ Если это про тебя, пиши в телегу @recruiter_maddevs с пометкой WEBSEC

🔭 Побольше узнать про отдел Mad Security можно на этой страничке: https://maddevs.io/cybersecurity/


Design Day 2.0: спикеры&темы 🤖

Митап состоится уже совсем скоро! А, значит, самое время рассказать вам о спикерах и темах, которые вас ждут во время ивента:

🎙 Влада Щербинина: “Нейронки: баланс инновации и реальности в дизайне”
🎙 Кристина Зюзина: “Почему мы любим милашек? Эмоциональный интеллект и soft-skills”
🎙 Клара Алымкулова: “Как подружиться со своими тараканами”
🎙 Екатерина Попова: “Дизайн — первый шаг в мир бизнеса”
🎙 Оман А. Абышев: “Отказываюсь выбирать или как построить карьеру своей мечты”
🎙 Вадим Андросов: “Как стать лидером в распределенной дизайн команде”
🎙 Дмитрий Толкачев: “UX/UI в крупных компаниях: выход за пределы стандартов”
🎙 Бек Тургунбаев: “Выйти за рамки: как “стресс” делает тебя лучше”

А также 🎙Алекс Кривов выступит в качестве модератора, но он также расскажет для вас много всего интересного.

Ждем вас:

📅 6 апреля 10:00
📍ololoPlanet, Юнусалиева 80, Бишкек

Участие абсолютно бесплатное!

Зарегистрироваться вы можете по ссылке.


Подборка полезных статей, новостей и инструментов

Мы видели ваши реакции 🔥, поэтому продолжаем рубрику всего самого интересного за неделю от наших сотрудников. Сегодня с вами на связи команда маркетинга!

🔹Что нового можем увидеть в JavaScript 2024

Cамые интересные и ожидаемые функций JavaScript, которые возможно появятся в 2024:
- Temporal API
- Pipe оператор
- Record и Tuple
- декораторы

Эти новинки еще пока на стадии предложения для добавления в спецификацию и велика вероятность, что именно они и попадут. Ждем дальнейших новостей!

🔹INP(Interaction to First Paint) теперь официально Core Web Vital

Напомним, что INP - это замена для показателя FID(First Input Delay). В связи с этим можно кинуть себе в закладки вот эту статью. Это полный гайд по INP, отвечающий на многие вопросы. Например, как улучшить этот показатель или почему INP был внедрен как замена для FID и многие другие.

🔹Safari 17.4

Смотрим, что стало поддерживаться в свежей версии Safari.
Из интересного:
- Promise.withResolvers()
- Object.groupBy()
- Element.checkVisibility()
Эти функции на данный момент стали поддерживаться всеми 3 основными браузерами.

🔹Observer

Советуем изучить этот сервис круглосуточного мониторинга сайта для углубленного анализа производительности. Такой прям Google Page Speed на максималках.

🔹Как вдохновить себя, если это навязанные обязательства

Как от саможалости и самопинков перейти к осознанности и осмысленности? В этой статье способ, как избавиться от этого деструктивного состояния. Если нельзя изменить задачу, поменяйте отношение к ней.


До следующей недели! 🤟


Mad Devs Meetups: Design Day 2.0 ⚡️

Мы возвращаемся! В прошлый раз всем настолько понравилось, что мы не могли не организовать Design Day еще раз. Приглашаем всех дизайнеров вновь принять участие в митапе, чтобы прокачать свои скиллы, обсудить горячие тренды и познакомиться с единомышленниками!

Что вас ждет:

📌 9 топовых лекций
📌 5 приглашенных спикеров
— «Выход за рамки»
📌 Нетворкинг

Save the date, как говорится:

📅 6 апреля 10:00

📍ololoPlanet, Юнусалиева 80, Бишкек

Участие абсолютно бесплатное!

Зарегистрироваться вы можете по ссылке.


Мы поучаствовали в ежегодном HTB Cyber Appocalypse CTF 2024 от HackTheBox.

HTB Cyber Appocalypse CTF - это всемирные соревнования, где команды в игровом формате решают задачи на взлом, чтобы найти спрятанные флаги. За каждый флаг начисляются очки, которые определяют место в рейтинге.

В этом году в соревнованиях участвовали 5693 команд и более 11000 участников. Наши сотрудники из Mad Devs были в составе команды Хакерстан и еще нескольких волонтеров. Им удалось занять 108 место в рейтинге. Это отличный старт и мы рады такому крутому опыту. В планах попробовать себя в этом в следующий раз!🔥


Олег Пузанов принял участие в подкасте “Цифровой горизонт”

"Цифровой Горизонт" - проект ОФ ГИИП, который создан для обсуждения влияния информационных технологий на современный Кыргызстан и в целом на весь мир.

Выпуск посвящен теме “Перспективы AI в Кыргызстане”, где спикеры и обсудили последние тренды и вопросы регулирования в этой сфере.

А что вы думаете о перспективах AI в Кыргызстане и мире? ⬇️


Подборка горячих новостей и крутых инструментов от Frontend Community

За кулисами Mad Devs обитают комьюнити по интересам и специализации от разработки до трейдинга и менеджмента. Простыми словами, там наши сотрудники прокачивают друг друга и выполняют разный стек задач.

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

🔹Управляем микрофронтендами
Fusionize - это orchestration платформа, помогающая настраивать, собирать и развертывать фронтенд-кусочки в единое веб-приложение.

🔹Интернет-драма с Apple и PWA
Apple хотели прекратить поддержку PWA приложений на домашнем экране, так как считают, что все приложения на домашнем экране должны проходить через AppStore, но потом передумали после жалоб. Пока не паникуем, но одним глазком наблюдаем!

🔹localStorage в современной разработке
Рассматриваем pros/cons localStorage и сравниваем с другими инструментами.

🔹Насколько JS растолстел в 2024
Негодуем о размерах JS в современных приложениях на английском и на русском.

Вам интересна такая рубрика? Оставьте реакцию - 🔥


О чем так мало говорят: типизация и протоколы в Python

Мы в Mad Devs заметили, что на курсах программирования типизации в Python уделяют не так много внимания. В основном новички знакомятся с базовыми концепциями вроде рекурсии или ООП, и тема остается в тени - кстати, незаслуженно, ведь она особенно важна, например, для коммерческой разработки.

Что такое типизация? Это механизм, который определяет тип данных для хранения в переменной.

Python использует динамическую типизацию, где тип переменной определяется во время присвоения значения.

С одной стороны, это удобно:

🔺 Не нужно заранее объявлять типы.
🔺 Код выглядит более лаконично.

С другой - может привести к ошибкам:

▪️Ошибки типов не определяются на этапе компиляции.
▪️ Код становится менее читаемым и понятным.

С подобными ошибками можно справиться двумя методами:

1. Аннотации типов позволяют явно указать типы переменных, функций и возвращаемых значений.
Статический анализатор mypy использует эти аннотации для проверки кода на потенциальные ошибки типов.

📝Пример:
def add(a: int, b: int) -> int:
return a + b
print(add(2, 5))
# Выводит 7

Эти аннотации просто дают знать программисту, какие типы должны иметь аргументы функции и результат какого типа она возвращает.

2. Утиная типизация для фокуса на методах, а не на типах. Утиная типизация говорит: "Если объект имеет нужный метод, то его тип не важен".

📝Пример:
def send_data(sender, data):
sender.send(data)

А как в этом примере дать понять mypy, что sender должен принимать класс с реализованным в себе методом send? Ответ прост — протоколы.

Что такое протоколы? Протоколы – это инструмент, который позволяет описать набор методов, чтобы реализовывать объект.

Сразу к примеру кода выше. Дополняем его:
from typing import (
Any,
Mapping,
Protocol,
)

class SenderProtocol(Protocol):
def send(data: Mapping[str, Any]) -> None:

Итого получаем:

def send_data(sender: SenderProtocol, data):
sender.send(data)

В данном примере:

Функция send_data принимает два аргумента:
sender: объект, который должен соответствовать протоколу SenderProtocol.
data: данные, которые будут отправлены методом send.

Благодаря протоколу:
📌Мы знаем, что объект sender имеет метод send.
📌Мы знаем, какой тип данных метод send принимает в качестве аргумента.
📌Мы знаем, какой тип данных метод send возвращает.

И задача решена!

В целом, типизация помогает упростить код, избавляя его от лишней писанины.
Однако для достижения этой цели важно знать протоколы, которые стандартизируют код. Это позволит создавать более читаемые, надежные и востребованные решения.


Защищай данные полностью: 7 лучших программ для шифрования

POV: вы занимаетесь разработкой ПО и проект содержит конфиденциальную информацию, такую как алгоритмы и спецификации продукта. Ваш компьютер заражается вирусом, который крадет ваши файлы и отправляет их конкурентам. Что будет после (спойлер: ничего хорошего)?

Будет следующее - конкуренты получат доступ ко всей конфиденциальной информации, и смогут использовать это, чтобы скопировать ваш продукт, вывести на рынок аналог раньше вас, в общем, нанести ущерб компании.

Поэтому шифрование данных — это не хотелка, не бонус, а необходимая мера для обеспечения безопасности. Слава Одину, это уже давно не нужно делать вручную.
Mad Devs сообрали для вас популярные программы для шифрования:

VeraCrypt
Бесплатное и открытое ПО для создания и управления зашифрованными томами данных, включая как тома, так и отдельные диски. Использует AES в режиме XTS, выбранный NIST как наиболее надежный стандарт шифрования. Кроме того, поддерживаются альтернативные алгоритмы — Twofish и Serpent.

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

ZuluCrypt
Предоставляет функциональность шифрования для дисков и устройств под управлением Linux, BSD и других UNIX-систем. Поддерживаемые стандарты включают LUKS, а также возможность использования контейнеров TrueCrypt и VeraCrypt.

Dexios
Эффективный и безопасный инструмент шифрования через командную строку, разработанный на языке программирования Rust. Поддерживает шифрование файлов перед их загрузкой в облачное хранилище. Основной алгоритм шифрования — AEAD (XChaCha20-Poly1305 + AES-256-GCM).

BitLocker
Инструмент шифрования дисков в Windows, обеспечивающий защиту данных от несанкционированного доступа. Программа использует алгоритм AES (Advanced Encryption Standard) в режимах, таких как AES-CBC (Cipher Block Chaining) и AES-XTS (XEX-based Tweaked CodeBook Mode with CipherText Stealing).

SiriKali
Универсальное решение в Linux для управления зашифрованными контейнерами и томами, поддерживающее LUKS, CryFS, EncFS и TrueCrypt/VeraCrypt. Программа использует алгоритмы AES, Twofish, Serpent и другие для защиты данных.

AxCrypt
Платное решение, применяющее симметричное шифрование с использованием алгоритма AES. Обеспечивает высокий уровень защиты данных благодаря блочному шифрованию с размером блока 128 бит и ключами 128, 192 или 256 бит. Также поддерживает шифрование данных в облаке.

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


Операция "Вставить": учимся работать с SQL INSERT! 🤖💬

Что общего у оператора INSERT и канцелярской кнопки? С помощью канцелярской кнопки мы можем закрепить бумагу, а с помощью оператора INSERT - закрепить данные в таблице. Давайте разберем его синтаксис и на примерах рассмотрим, как он применяется на практике.

Оператор INSERT в SQL - это мощный инструмент, который позволяет добавлять новые записи в таблицы базы данных.

Синтаксис:

INSERT INTO название_таблицы (список_столбцов)
VALUES (значения_столбцов);

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

Теперь посмотрим примеры использования SQL оператора INSERT. Представим, у нас есть таблица “Клиенты” с полями: 'Имя', 'Фамилия' и 'Email'. Чтобы добавить нового клиента, воспользуемся запросом:

INSERT INTO Клиенты (Имя, Фамилия, Email)
VALUES ('Иван', 'Иванов', 'ivan@example.com');

Мы также можем добавить несколько записей за раз:

INSERT INTO Заказы (Номер, Дата)
VALUES (101, '2023-01-15'),
(102, '2023-01-16'),
(103, '2023-01-17');

А с помощью оператора INSERT и SELECT переносим данные из временной таблицы:

INSERT INTO Заказы (Номер, Дата)
SELECT Номер, Дата
FROM Временные_Заказы
WHERE Дата > '2023-01-01';

Также можно использовать подстановочные знаки:

DECLARE @Имя NVARCHAR(50) = 'Иван';
DECLARE @Фамилия NVARCHAR(50) = 'Иванов';

INSERT INTO Клиенты (Имя, Фамилия)
VALUES (@Имя, @Фамилия);

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

Используете SQL INSERT в работе? Почему да? Почему нет? Хотим ваших мнений в комментариях!


Полезные сервисы для подготовки к техническим собеседованиям 🖥

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

Боитесь провалиться на собеседовании? Не волнуйтесь, вы не одиноки. Технические собеседования могут быть очень сложными, особенно если вы не знаете, чего ожидать. Вам в помощь мы собрали сервисы, которые помогут вам в подготовке.

IT Resume
Один из редких ресурсов на русском языке, где вы можете оценить свои технические навыки. Здесь вы найдете задачи по алгоритмам и структурам данных, синтаксису языков программирования, а также реальные задачи с собеседований.

LeetCode
Эта платформа, пользующаяся высокой популярностью, предоставляет обучающие материалы, которые помогут освежить знания и подготовиться к собесам. Вы найдете разнообразные задачи по алгоритмам и структурам данных с уровнями сложности. Поддерживаются различные языки программирования. Сотрудничество с компаниями: размещение вакансий и поиск работы для пользователей.

CodeSignal
Платформа предлагает широкий выбор заданий, поддержку 70 языков, продвинутую среду разработки, соревнования, обратную связь и сотрудничество с IT-компаниями.

InterviewBit
Универсальная платформа с широким выбором задач, детальными решениями, имеется онлайн-среда разработки и практика на реальных задачах от известных IT-компаний.

Pramp
Уникальная онлайн-платформа, которая позволяет вам практиковаться в прохождении собеседований с помощью ролевых игр. Можно выбрать тип интервью, а также получить персонализированный фидбэк от профессионалов.

Interviewing.io
Популярная платформа для подготовки, на которой представлены реальные собеседования в стиле FAANG. Вы можете выбрать анонимный формат и получить объективную обратную связь по hard skills и soft skills.

Расскажите в комментариях, какие ресурсы используете вы 👇


Управляй зависимостями! Полезный туториал по Cargo в Rust

Знаем, что тех, кто знаком с Rust, становится все больше. Именно с вами хотим поделиться возможностями Cargo - который, как туристический гид, нежно и профессионально отвечает за то, чтобы вы не заблудились в зависимостях и не пропустили ничего интересного.

Что нужно знать

Cargo - это система сборки и управления пакетами, которая помогает разработчикам Rust создавать, собирать, тестировать и публиковать свои проекты:

📍 Автоматически управляет зависимостями, интегрируя сторонние библиотеки.
📍 Обеспечивает компиляцию и сборку проекта, учитывая все зависимости.
📍 Позволяет запускать тесты для поддержания высокого качества кода.
📍 Помогает генерировать автоматическую документацию для вашего кода.
📍 Позволяет публиковать и устанавливать пакеты из официального репозитория Rust, Crates.io.

Вот основные команды:

📍 cargo new создает новый проект, инициализируя его структуру и зависимости.
📍 cargo build автоматически управляет зависимостями и обеспечивает правильную сборку.
📍cargo run компилирует и запускает код, а cargo test упрощает тестирование.
📍 cargo doc создает просматриваемую документацию на основе комментариев в коде.
📍 Для библиотек и пакетов используйте cargo publish для упрощения публикации на Crates.io*.

Простой пример:

Чтобы создать новый проект Rust, используйте команду cargo new my-project. Эта команда создаст новый каталог my-project с файлами проекта, включая файл Cargo.toml.
Далее, чтобы скомпилировать проект Rust, используйте команду cargo build. Эта команда скомпилирует проект и создаст исполняемый файл.
Затем запускаем код Rust, используя команду cargo run. Команда скомпилирует и запустит код.
Чтобы протестировать код Rust, используйте команду cargo test. Эта команда запустит все тесты в проекте.
Ну для того, чтобы сгенерировать документацию для кода Rust, используйте команду cargo doc. Эта команда создаст документацию в формате HTML.


Найди 10 отличий: модуль. Пакет. Библиотека. Фреймворк

Новички в программировании часто путают модули, пакеты, библиотеки и фреймворки. Это нормально! В них легко запутаться, потому что они могут частично дублировать функционал друг друга. Давайте разберемся в этих терминах простым языком.

Так понятия описывают в учебниках и статьях:

📌Модуль (Module) — в Python представляет собой логически обособленный сниппет кода в отдельном файле с расширением .py. Модули помогают улучшить структуру кода, позволяя сосредотачиваться на отдельных частях задачи, избегать дублирования кода и минимизировать вероятность конфликта имен.

📌Пакет (Package) — каталоги модулей с иерархической структурой пространства имен. Он служит для группировки и упорядочивания модулей, предоставляя организацию, аналогичную распределению файлов на жестком диске в папках и подпапках.

📌 Библиотека (Library) — объект, который находится на более высоком уровне, содержащий связанные модули и/или пакеты.

📌 Фреймворк (Framework) — в контексте разработки программ представляет собой набор модулей и пакетов, предназначенных для ускорения процесса программирования. Фреймворки более сложны и обладают архитектурой приложения. Известные представители класса – Django, Flask и Bottle.

Как объясним это мы? Очень просто:

Модуль — инструменты в ящике с инструментами. Они используются для выполнения определенных задач.
Пакет — коробка с инструментами. То есть это контейнеры, в которых хранятся модули.
Библиотека — набор инструментов. Это наборы модулей, которые предоставляют определенные функции или возможности.
Фреймворк — инструкция по сборке мебели. Это набор правил и ограничений, которые определяют, как должна быть построена программа.

Сохраните себе эту небольшую подсказку, но помните – полное понимание приходит только на практике. Попробуйте использовать модули, пакеты, библиотеки и фреймворки в своих собственных проектах.


Как правильно писать bug-report: готовый шаблон от Mad Devs

Мы спросили наших разработчиков, какая проблема остается одной из самых актуальных в коммуникации с менеджерами. Ответ прозвучал незамедлительно: написание баг репортов. Некоторые до сих пор считают, что писать подробный баг-репорт — это слишком долго и трудоемко, и, экономя время, отписывают разработчику короткое сообщение в личной переписке.

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

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


Приоритизация задач по методу MoSCoW 📊

Представьте, что вы работаете над новым продуктом. Вы собрали команду, разработали план, но столкнулись с проблемой: задач слишком много. Как определить, какие задачи следует реализовать в первую очередь, а какие можно отложить?

На помощь приходит метод MoSCoW.

📌Метод MoSCoW - это простой способ расставить приоритеты задач. Он основан на двух критериях: важности и срочности. В аббревиатуре MoSCoW скрыты четыре категории требований:

➕Must-have - обязательно нужно сделать.
✔️Should-have - желательно сделать, но можно отложить.
♾ Could-have - можно сделать, если есть время и ресурсы.
➖Won't-have - не будем делать.

Вот пример того, как можно использовать метод:

Проект: Разработка нового приложения для мобильных устройств

Задачи:
Must-have: Добавить возможность регистрации с помощью социальных сетей
Should-have: Добавить возможность создания собственных списков
Could-have: Добавить функцию перевода
Won't-have: Добавить возможность 3D-просмотра


Как видите, метод MoSCoW позволяет быстро и легко расставить приоритеты для задач. Но у него есть и недостатки.

Во-первых, это субъективность. Члены команды могут иметь разные взгляды на важность и срочность задач, а это ведет к разногласиям. Что поможет? Объективная система оценки.

Во-вторых, это статичность. Приоритеты задач могут меняться со временем, в зависимости от условий. Какой выход? Не забывать пересматривать приоритеты.

Если вы хотите повысить свою продуктивность и улучшить результаты работы, попробуйте использовать этот метод.


Как сторителлинг помогает в аналитике 📚

В 2009 году журналисты Роб Уокер и Джошуа Гленн провели интересный эксперимент, демонстрирующий, как эмоции могут повысить стоимость товара. Они обнаружили, что люди были готовы платить больше за бутылку вина, если им рассказывали историю о том, как она была изготовлена.

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

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

Вы можете использовать сторителлинг, чтобы создать историю о гипотетическом пользователе, который ищет дополнение к 1С. Эта история могла бы включать в себя такие элементы, как:

📌 Цели пользователя: Чего пользователь хочет достичь, покупая дополнение? Например, хочет ли он автоматизировать свой бизнес или улучшить эффективность работы?

📌 Задачи пользователя: Какие шаги пользователь должен предпринять, чтобы достичь своих целей? Например, он должен найти дополнение, которое соответствует его потребностям, прочитать описание, изучить отзывы и проверить совместимость.

📌 Сложности, с которыми сталкивается пользователь: Какие препятствия могут возникнуть на пути пользователя? Например, он может столкнуться с медленной загрузкой страницы, неясным описанием или отсутствием информации о совместимости.

“Распаковав” эти элементы, вы можете создать историю, которая будет интересна и актуальна для вашей целевой аудитории, потому что будет бить точно в боль Еще такая история может помочь вам понять, как улучшить пользовательский опыт и повысить конверсию.

📕 Бонус: Если вам интересна эта тема, то обратите свое внимание на книгу Коул Нассбаумер Нафлик «Данные: визуализируй, расскажи, используй».


6 типичных ошибок новичков в Python

«Выстрелить себе в ногу» в программировании — это создание кода, способного сломать программу, но при этом не вызвать ошибку, позволяет программе продолжить работу. Термин произошел от описания рисков неосторожных действий в языке программирования C/C++. Но, на самом деле, это касается и других языков программирования.

Например, Python назвали «двуствольным обрезом», который иногда стреляет неудобствами, но трудно предсказать, когда именно.

Если вы только начали изучать программирование, не переживайте, стрелять в ногу — это нормально. Давайте разберемся с разными ошибками в Python, чтобы сократить риск ошибок в коде:

📝 Невнятное именование
Чёткие имена переменных облегчают чтение кода и уменьшают ошибки.
📝 Внешние модули вместо встроенных
Использование встроенных модулей Python обеспечивает стабильность, переносимость и производительность.
📝 Проверка типов
Проверять, с чем работают те или иные функции/методы — хороший способ избежать незапланированного поведения программы и повысить безопасность.
📝 Обработка исключений
Использование try-except помогает избежать прерываний в работе программы и упрощает отладку.
📝 Отсутствие тестов
Создание даже несовершенных тестов лучше, чем выпуск приложения без них.
Начните с простых тестов и постепенно улучшайте навыки тестирования.
Рекомендуется дополнительно изучить тестирование, особенно если вы планируете работать в продакшене.
📝 Не закрывать файлы и ресурсы
Неосвобожденные ресурсы могут привести к утечкам памяти и проблемам с ресурсами.

Следуя этим небольшим рекомендациям, можно облегчить свой путь в Python и стрелять по запланированным «мишеням».


Подсказка по промптам📖

Промпт-инжиниринг — это стратегии и тактики для создания, оценки и улучшения запросов, которые мы отправляем ИИ-моделям, таким как ChatGPT. Для достижения наилучших результатов важно понимать логику и функционал ИИ, а также использовать это понимание.

Техника для создания запросов следующая:

📌 Вы можете указать желаемый тон, стиль и лексику, добавив соответствующие инструкции в запрос, например, "напиши официально" или "изложи как разговор".

📌 Четко определите желаемую структуру ответа, объем, разбивку на разделы или установите ограничения по времени и формату, чтобы более точно управлять результатом.

📌 Многие модели ИИ поддерживают специальные системные команды, которые позволяют настроить параметры, такие как максимальная длина текста.

📌 Включите в запрос информацию, которая обеспечит ИИ необходимым контекстом для выполнения запроса и понимания нюансов.

📌 Разбейте сложные задачи на последовательность более простых запросов, где результат одного запроса становится входом для следующего.

📌 Экспериментируйте с разными формулировками и систематически тестируйте запросы, чтобы найти наилучший вариант и улучшить их со временем.

Есть ли у вас советы по работе с ИИ? Поделитесь ими в комментариях 👇


"Джун уронил прод."

Помните реальную историю джуна-разработчика, опубликованную на Reddit в 2017 году? 🤔

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

Далее в ветке обсуждения родился чек-лист, который поможет джунам избежать подобных ошибок:

📌 Внимательно проверяйте инструкции и параметры перед запуском скриптов.
📌 Работайте с тестовыми данными и базами данных в отдельной среде, избегая работы с реальными данными.
📌 Создавайте резервные копии перед важными операциями.
📌 Запрашивайте подтверждение и разъяснения у более опытных коллег, если возникают сомнения.
📌 Соблюдайте процедуры безопасности и контроля качества, чтобы избежать случайных удалений или повреждения данных.

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

Показано 20 последних публикаций.