-
Notifications
You must be signed in to change notification settings - Fork 194
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
ic()
prints extremely slowly when in a VS Code Jupyter Notebook
#100
Comments
i'd guess this has to do with colorama... |
@pridkett thank you for recording a video! that's extremely helpful
indeed my gut says the same 🙂. let's find out! @pridkett if you don't mind, can you please try this snippet in your jupyter notebook: import sys
from icecream import ic
def stderrPrint(*args):
print(*args, file=sys.stderr)
ic.configureOutput(outputFunction=stderrPrint)
for x in range(5):
ic()
|
could also try a script that prints things with colorama unrelated to icecream |
Using the custom But, then again, taking @alexmojaki's hint and writing some colorama directly, was also zippy fast: Looks like I'll have to dig deeper here. |
really interesting result. great testing there 🙌 im not familiar with colorama's guts. i dont know offhand why icecream's use of colorama, which in its entirety is: @contextmanager
def supportTerminalColorsInWindows():
# Filter and replace ANSI escape sequences on Windows with equivalent Win32
# API calls. This code does nothing on non-Windows systems.
colorama.init()
yield
colorama.deinit() produces chunky output in jupyter notebook
if you have the time, please do and let us know what you find! thank you 🙌 @alexmojaki depending on what @pridkett finds, this may be (yet another) nail in the colorama's coffin for us |
I think the |
I've spent some time digging at this. What's happening in Jupyter notebooks is that colorama is incorrectly saying that the ANSI codes need to be stripped out because it's Jupyter web and Jupyter VS Code are not TTYs. In fact, you don't need to strip out color codes inside of Jupyter Web and VS Code, so this should have a workaround similar to how PyCharm currently has a workaround in colorama. The net impact of this is what colorama creates a wrapped version of This also explains why in my gif above it looks like all the lines from The "fix" is to make it so colorama doesn't think it needs to strip out the colors when running in Jupyter notebooks, which can handle coloring just fine. Not a bug in icecream, a bug in colorama. |
@pridkett awesome digging! thank you! 🙌
a few options:
#2 is best overall but the most effort. #1 is a nice to have and medium effort. #3 solves the immediately problem in a hacky way but degrades ic's experience @pridkett is there an environment variable present in jupyter notebooks, akin to the if so, we can submit a quick PR to add jupyter notebook as an exception to colorama |
+1 this. I love icecream but currently unusable in notebooks. @gruns - I ran os.environ from within a notebook and there seems to be a relevant env var: A quick google search confirmed that it's set by the notebook and I also confirmed that it disappeared when the notebook wasn't running. |
@peedrr great digging! 🙌 can you check out a local version of icecream and a local version of colorama therein, and then add elif 'JPY_PARENT_PID' in os.environ:
return False to def isatty(self):
stream = self.__wrapped
if 'PYCHARM_HOSTED' in os.environ:
if stream is not None and (stream is sys.__stdout__ or stream is sys.__stderr__):
return True
elif 'JPY_PARENT_PID' in os.environ:
return False
try:
stream_isatty = stream.isatty
except AttributeError:
return False
else:
return stream_isatty() and see if that correctly disables coloring in jupyter notebooks and thus resolves icecream's slow output? if so, ill submit that PR as a quick 'fix' in the vein of #5 above
if its not merged quickly (looking at how active colorama is, i doubt it will be), ill add a workaround to icecream itself |
@gruns - I just wanted to ack your message. I'm a bit snowed under but I'll get around to it. Thanks for the step-by-step and for your responsiveness. I'll get back to you |
@peedrr appreciate the heads up! ❤️ |
You can use the following code to work around the but in colorama. if "JPY_PARENT_PID" in os.environ:
import colorama.ansitowin32 as ansito_win32
# https://github.com/tartley/colorama/blob/136808718af8b9583cb2eed1756ed6972eda4975/colorama/ansitowin32.py#L49
# monkey patching colorama to work with jupyter
# replace StreamWrapper.isatty with a lambda that returns True
ansito_win32.StreamWrapper.isatty = lambda self: True |
This is probably a niche issue, but I saw that it was also discussed in #36 (see this comment by matthewdm0816 for a little bit of the details).
In short, when using
ic()
with the default configuration in a Jupyter Notebook and Visual Studio code, there is some sort of interaction that makes the output almost appear to be character by character. The following low framerate gif shows the problem:The text was updated successfully, but these errors were encountered: