Я использовал следующую функцию для проверки исходного кода функции при работе с лабораторией/ноутбуком Jupyter:
def source(function):
print(inspect.getsource(function))
Для более коротких кодов это нормально, но в какой-то момент подсветка кода может оказаться удобной. Таким образом, я изучил использование Pygments:
def source2(function):
from IPython.core.display import HTML, display
from pygments import highlight
from pygments.lexers import PythonLexer
from pygments.formatters import HtmlFormatter
code = inspect.getsource(function)
html = highlight(code, PythonLexer(), HtmlFormatter(style='colorful'))
display(HTML(html))
Хотя кажется, что это создает промежуточный HTML-код и отображает его правильно, код остается простым (без выделения). Промежуточная строковая переменная "html" имеет следующее содержимое.
'<div class="highlight">
<pre><span>
</span><span class="k">def</span>
<span class="nf">source</span>
<span class="p">(</span>
<span class="n">function</span>
<span class="p">):</span>\n
<span class="k">print</span>
<span class="p">(</span>
<span class="n">inspect</span>
<span class="o">.</span>
<span class="n">getsource</span>
<span class="p">(</span>
<span class="n">function</span>
<span class="p">))</span>\n
</pre></div>\n'
Я полагаю, что мне может просто не хватать файла CSS?
Бонусный вопрос (может быть разделен позже): есть ли способ использовать это в функции через контекстное меню правой кнопки мыши или горячую клавишу в лаборатории/ноутбуке Jupyter?