Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Python: docstring, inspect

Как получить docstring функции программно?

Вопрос проверяет знание механизмов introspection и работы с метаданными функций.

Короткий ответ

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

Длинный ответ

Python предоставляет несколько способов программного доступа к документации объектов.

Прямой доступ

Самый простой вариант — использовать атрибут:

def foo():
    """Example docstring"""
    pass

print(foo.__doc__)

Если docstring отсутствует, значение будет None.


Использование inspect

Модуль inspect предоставляет более удобный интерфейс:

import inspect

inspect.getdoc(foo)

Этот способ:

  • нормализует отступы

  • корректно работает с унаследованными docstring

  • безопаснее для сложных случаев


Где это используется

Получение docstring важно для:

  • автодокументации

  • CLI-инструментов

  • фреймворков

  • интроспекции в рантайме


Краткий вывод

Docstring можно получить напрямую через __doc__, но для надёжной работы и сложных сценариев предпочтительнее использовать inspect.getdoc.

  • Аватар

    Python Guru

    Sergey Filichkin

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    4

  • Сложность:

    3

Навыки

  • Python

    Python

Ключевые слова

#docstring

#inspect

Подпишись на Python Developer в телеграм

  • Аватар

    Python Guru

    Sergey Filichkin

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.