-
-
Notifications
You must be signed in to change notification settings - Fork 1.2k
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
logging-format-interpolation for f-strings #1788
Comments
Thanks! |
Please not! f-Strings are more readable and fast. We don't want to mix old-style and new-style formatting in our code (this is IMHO worse than not using |
@PCManticore Or give it at least a different error message (e.g., |
A different message sounds good to me, if you can please create an issue with it, that would be great! Nevertheless, f-strings might be fast, but there's no need to compute them if there is no need to emit the logging message if its under the expected logging level. |
@sscherfke as @PCManticore hinted at, the reason that pylint emits the logging-format-interpolation warning is because it is inefficient to compute the string for a log message that won't be logged. This also applies to f-strings, since even if they are faster than I share your opinion on the greatness of f-strings, but if you are using them with the logging module, you are using the logging module incorrectly/inefficiently. |
Sometimes I just don care. Practicality beats purity. 😉 |
I agree with @sscherfke. Code readability out weights the tiny efficiency increase. |
Seconded. IMO mixing old-style formatting and f-strings throughout the application is less desirable than the cost of computing the string interpolation. |
Commenting on this issue won't change anything, if you don't agree with the warning, feel free to disable it, but this is going to be the default in pylint. |
Python not being my first nor preferred language. It does make it harder to quickly read and understand code. I agree with the above sentiments. I thought the goal of linters was to make code consistent and easier to parse. |
Please see the timing results at #2395 Those findings indicate that the difference in performance when logging messages are suppressed is minimal at best (~1%), and if logging statements are emitted then f-strings are actually more performant (though again, the performance difference is so small that it's not worth preferring either for performance reasons). |
Yeah, this warning seems like hardcore premature optimization.
These kinds of decisions for defaults should be made by consensus rather than by fiat. Also, the imperious tone is not appreciated. |
How about an option to exempt f-strings? By default, they would be flagged; with this option on, no. |
You know what's even faster? Not logging at all and not writing any messages. How about an option on pylint prudent behaviour for any stdout output? |
There's one reason I drop down from f-strings to regular modulus interpolation: queryset = MyModel.objects.relevant()
logger.debug('About to do the dirty to: %s', queryset) If that queryset is evaluated when log level = INFO, we're talking far more than a 1% performance difference. |
The benefits of using f-strings in logs are proven - enhanced readability and less writing effort. The downsides are highly speculative; only come into play if logging does not really occur && the f-string contains costly operations. Controversial coding style practices should not be addressed in such a common dev tool. primum non nocere |
Just commenting to add that I have no particular bone in this game, save that I value consistency over 'practicality'. Also, if people had actually read the original bug report, you'd have noticed that my main gripe is that Pylint doesn't warn against attempting logging strings that will crash the logger in the case of f-strings, which can happen when you inadvertently mix different string interpolation methods.
Sure, it's an edge case, and that pylint warns against the first logging attempt is a lucky side effect of how the logging-format-interpolation warning works, but that warning still would prevent people from writing code that leads to runtime crashes, which I think is fairly practical. In other words I see no problem with allowing |
It seems like everyone here is talking about performance. There are other benefits to letting
|
This all has nothing to do with pylint. If each kind of interpolation raises a different pylint warning, users can customize pylint to match their world-view on logging. The discussion which one is the best can be conducted elsewhere. ;-) |
@sscherfke I think the discussion is ultimately what should be the default for pylint. |
pylint-dev/pylint#1788 Signed-off-by: Kai Xia <xiaket@gmail.com>
* chore: %-formatting to f-string pylint-dev/pylint#1788 (comment) --- Jakub I didn't agree with using f-strings in logging calls because I don't think log messages need to be super simple to read. If in the future you find out it was stupid idea, then remember that it was a Jakub's stupid decision. ---- Closes #144
Can you explain what you mean, @theY4Kman ? It seems to me that you are calculating Thanks! |
The configuration for fstring is avaialble since pylint 2.4 and was introduced in eeca6cf. See, http://pylint.pycqa.org/en/latest/whatsnew/2.4.html?highlight=fstring%20interpolation
I'm going to lock to prevent further discussions here. |
Pylint will warn against using .format and % when logging. As the example below shows, I think it would be prudent to also output warnings when using f-strings.
Steps to reproduce
Current behavior
Pylint does not warn against f-string interpolation in loggers.
Expected behavior
Pylint should warn against f-string interpolation in loggers, just as it warns against .format-interpolation.
pylint --version output
The text was updated successfully, but these errors were encountered: