Python Portal
55.2K subscribers
2.48K photos
404 videos
51 files
1.02K links
Всё самое интересное из мира Python

Связь: @devmangx

РКН: https://clck.ru/3GMMF6
Download Telegram
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥4711😁9🌭3
This media is not supported in your browser
VIEW IN TELEGRAM
Agentic RAG для чайников

Модульный agentic RAG, собранный на LangGraph. Разберись с RAG-агентами за считанные минуты.

Этот репозиторий показывает, как собрать agentic RAG на LangGraph с минимумом кода.

Что обещают в README, если коротко:

- иерархическая индексация (parent/child чанки: ищем по мелким, достаём крупные для контекста)
- память диалога
- уточнение запроса (вплоть до паузы и вопроса пользователю)
- оркестрация пайплайна через LangGraph, плюс параллельный map-reduce для сложных запросов
- автоперезапрос, если результатов мало, и компрессия контекста, чтобы не раздувать промпт

https://github.com/GiovanniPasq/agentic-rag-for-dummies

👉 @PythonPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
7
Гвидо ван Россум (отец Python) выпустил новую версию typeagent, Python-библиотеки, над которой он работал с середины прошлого года, и все больше делал это вместе с Claude. Она реализует память для агентов.

Установка: pip install typeagent.

CHANGELOG.md

👉 @PythonPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
👀8👍42
🧠🧠🧠

👉 @PythonPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
43😁22🌭3🤣2👍1🤔1
Новый PEP

Ограничения в софтверной инженерии созданы, чтобы их ломать. Годами меня бесил разрыв между Python и TypeScript: у одного невероятно динамичный и мощный рантайм, у другого невероятно динамичная и мощная система типов.

Так почему бы не совместить и то, и другое? 🔥

Встречайте PEP 827, результат годового ресерча о том, что нужно, чтобы прокачать type checking в Python до уровня его динамичности.

Вот как можно реализовать Record, сравнив варианты бок о бок:

TypeScript

type Record<K extends string, V> = {
[P in K]: V
}

// так что...

type Fruit = Record<
'apple' | 'banana' | 'orange',
string
>

// развернется в
//
// {
// apple: string;
// banana: string;
// orange: string;
// }


Python

type Record[K, V] = NewTypedDict[
*[Member[k, V] for k in Iter[FromUnion[K]]]
]

# так что...

type Fruit = Record[
Literal["apple", "banana", "orange"],
str
]

# развернется в
#
# class <Fruit>:
# apple: str
# banana: str
# orange: str


Вот пример Pick:

TypeScript

type Pick<T, K extends keyof T> = {
[P in K]: T[P]
}


Python

type Pick[T, K] = NewProtocol[*[
p for p in Iter[Attrs[T]]
if IsAssignable[p.name, K]
]]


А вот Omit. Обрати внимание: версия на Python по сути не изменилась по сравнению с реализацией Pick, в отличие от TS.

TypeScript

ts id="5ehk8a"
type Omit<T, K extends keyof T> = {
[P in Exclude<keyof T, K>]: T[P]
}


Python

py id="g6u8k1"
type Omit[T, K] = NewProtocol[*[
p for p in Iter[Attrs[T]]
if not IsAssignable[p.name, K]
]]


👉 @PythonPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
5👀1
Немного базы Python. # 12 - Startswith и Endswith

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

- Использование метода Startswith

Допустим, ты хочешь получить все имена в списке, которые начинаются на a. Вот как можно использовать startswith() для этого:

list1 = ['lemon', 'Orange',
'apple', 'apricot']

new_list = [fruit for fruit in list1 if fruit.startswith('a')]
print(new_list)


['apple', 'apricot']


- Использование метода Endswith

Метод endswith() можно использовать для валидации ввода пользователя. Например, если нужно проверить, что пользователь ввёл корректный Gmail-адрес, можно убедиться, что ввод заканчивается на gmail.com:

user_input = input("Введите email-адрес: ")

if user_input.endswith("@gmail.com"):
print("Валидный email-адрес.")
else:
print("Невалидный email-адрес.")


👉 @PythonPortal #100daysofpython
Please open Telegram to view this post
VIEW IN TELEGRAM
10🤔3👍2