-
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
ISC001: False positive for comma-separated strings #12902
Comments
Hey thanks! I was just going to make a issue for this :D
|
@VeckoTheGecko the rule seems correct to me. At least, I don't think your code produces what you want. Here a more simple example: >>> "Dataset not found. Available datasets are: " ", ".join(["a", "b", "c"])
'aDataset not found. Available datasets are: , bDataset not found. Available datasets are: , c' I don't think that's what you want. The problem is that the f"Dataset {dataset!r} not found. Available datasets are: " ", ".join(example_data_files.keys())
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^
string 1 string 2 You probably want: f"Dataset not found. Available datasets are: '{", ".join(["a", "b", "c"])}'" (Only works with Python 3.12 or newer) |
I agree with @MichaReiser; I think Ruff is accurately flagging here that your code isn't doing quite what you thought it did. Another thing that also demonstrates that Ruff's interpretation of the code here is correct is that CPython eagerly merges the two adjacent strings when parsing the AST -- the >>> import ast
>>> source = '''ValueError("Dataset {dataset!r} not found. Available datasets are: " ", ".join(example_data_files.keys()))'''
>>> print(ast.dump(ast.parse(source), indent=2))
Module(
body=[
Expr(
value=Call(
func=Name(id='ValueError', ctx=Load()),
args=[
Call(
func=Attribute(
value=Constant(value='Dataset {dataset!r} not found. Available datasets are: , '),
attr='join',
ctx=Load()),
args=[
Call(
func=Attribute(
value=Name(id='example_data_files', ctx=Load()),
attr='keys',
ctx=Load()),
args=[],
keywords=[])],
keywords=[])],
keywords=[]))],
type_ignores=[]) |
Yes, it's a bug on my end. Thanks for the reply, didn't know implicit concatenation worked like that. Need to be a bit more careful with my multiline implicit concats |
@VeckoTheGecko: Honestly, implicit string concatenation is a horrible feature best avoided. But https://peps.python.org/pep-3126/ was rejected, so we have to put up with it. |
Not sure if this is the right thread (maybe this should be a new issue), but there is a conflict between ISC001 and Ruff format if the string has a method associated with it.
Of course, those string literals can't be combined because of the join.
Originally posted by @VeckoTheGecko in #8272 (comment)
Very basic example:
Flags ISC001 but there's no implicit string concatenation because a comma separates the strings (playground).
The text was updated successfully, but these errors were encountered: