-
-
Notifications
You must be signed in to change notification settings - Fork 46k
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
fixes join.py and split.py action and requirements error #12438
Conversation
for more information, see https://pre-commit.ci
for more information, see https://pre-commit.ci
strings/join.py
Outdated
if not all(isinstance(word_or_phrase, str) for word_or_phrase in separated): | ||
raise Exception("join() accepts only strings") | ||
|
||
joined = separator.join(separated) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Question about this join though. Isn't the point of this repository to show possible implementations of python functions? Because if that's the case, I was wondering why the join function now internally uses str.join?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
okay I understood! Now I'll try to implement something which manually constructs the resulting string without relying on Python's built-in str.join()
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
seems fine but why the join function now internally uses str.join? as what @Kaaserne said
for more information, see https://pre-commit.ci
strings/join.py
Outdated
for i, element in enumerate(separated): | ||
result += element | ||
if i < len(separated) - 1: # Add separator only between elements | ||
result += separator | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@Kaaserne can you please review it?
strings/join.py
Outdated
|
||
Examples: | ||
|
||
>>> join("", ["a", "b", "c", "d"]) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What's the reason these got removed? I've never used doctest
before but I think this has something to do with testing. Maybe you can also add:
"""
>>> join(',', ['', '', ''])
',,'
"""
strings/join.py
Outdated
""" | ||
if not all(isinstance(word_or_phrase, str) for word_or_phrase in separated): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this if statement, with the removal of all
, can be placed inside the for-loop. That way we only iterate over the sequence once, instead of twice.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for your advice. sure lemme check
for more information, see https://pre-commit.ci
Reversed |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please split this PR to several - one PR for one issue (especially if the issues are not related as in this case)
And this PR has failed doctests
>>> join("#", "a") # Single string instead of list
Expected:
Traceback (most recent call last):
...
Exception: join() accepts only strings
Got:
'a'
Reversed |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Describe your change:
Fixes #12346
Checklist:
For #12346