Title: Backslash in f-string format specifier gets escape · Issue #105194 · python/cpython · GitHub
Open Graph Title: Backslash in f-string format specifier gets escape · Issue #105194 · python/cpython
X Title: Backslash in f-string format specifier gets escape · Issue #105194 · python/cpython
Description: Bug report Between Python 3.12 alpha 7 and beta 1 the behaviour of format specifiers containing a backslash (e.g. \n, \u2603) in f-strings changed. Previously, the __format__ method would get e.g. the newline character, but it now receiv...
Open Graph Description: Bug report Between Python 3.12 alpha 7 and beta 1 the behaviour of format specifiers containing a backslash (e.g. \n, \u2603) in f-strings changed. Previously, the __format__ method would get e.g. ...
X Description: Bug report Between Python 3.12 alpha 7 and beta 1 the behaviour of format specifiers containing a backslash (e.g. \n, \u2603) in f-strings changed. Previously, the __format__ method would get e.g. ...
Opengraph URL: https://github.com/python/cpython/issues/105194
X: @github
Domain: github.com
{"@context":"https://schema.org","@type":"DiscussionForumPosting","headline":"Backslash in f-string format specifier gets escape","articleBody":"\u003c!--\r\n If you're new to Python and you're not sure whether what you're experiencing is a bug, the CPython issue tracker is not\r\n the right place to seek help. Consider the following options instead:\r\n\r\n - reading the Python tutorial: https://docs.python.org/3/tutorial/\r\n - posting in the \"Users\" category on discuss.python.org: https://discuss.python.org/c/users/7\r\n - emailing the Python-list mailing list: https://mail.python.org/mailman/listinfo/python-list\r\n - searching our issue tracker (https://github.com/python/cpython/issues) to see if\r\n your problem has already been reported\r\n--\u003e\r\n\r\n# Bug report\r\n\r\nBetween Python 3.12 alpha 7 and beta 1 the behaviour of format specifiers containing a backslash (e.g. `\\n`, `\\u2603`) in f-strings changed.\r\n\r\nPreviously, the `__format__` method would get e.g. the newline character, but it now receives a backslash and an `n` character (i.e. the string `\"\\n\"`)\r\n\r\nThe following script demonstrates this:\r\n\r\n```python3\r\n# issue.py\r\n\r\nclass F:\r\n\tdef __format__(self, format_spec):\r\n\t\tprint(\"spec:\", repr(format_spec))\r\n\t\treturn format_spec.join([\"a\", \"b\", \"c\"])\r\n\r\nprint(\"out: \", repr((f\"{F():\\n}\")))\r\nprint(\"out: \", repr((f\"{F():\\u2603}\")))\r\n\r\nprint(\"out: \", repr((format(F(), \"\\n\"))))\r\nprint(\"out: \", repr((format(F(), \"\\u2603\"))))\r\n```\r\n\r\n```console\r\n$ python3.11 issue.py\r\nspec: '\\n'\r\nout: 'a\\nb\\nc'\r\nspec: '☃'\r\nout: 'a☃b☃c'\r\nspec: '\\n'\r\nout: 'a\\nb\\nc'\r\nspec: '☃'\r\nout: 'a☃b☃c'\r\n```\r\n\r\n\r\n```console\r\n$ python3.12 issue.py\r\nspec: '\\\\n'\r\nout: 'a\\\\nb\\\\nc'\r\nspec: '\\\\u2603'\r\nout: 'a\\\\u2603b\\\\u2603c'\r\nspec: '\\n'\r\nout: 'a\\nb\\nc'\r\nspec: '☃'\r\nout: 'a☃b☃c'\r\n```\r\n\r\nIn both cases the `format()` function works correctly - I only encounter the issue with f-strings.\r\n\r\nI suspect this is related to the PEP 701 changes to f-strings, but I couldn't find anything in the discussion of that PEP to suggest this was a deliberate change.\r\n\r\n\r\n# Your environment\r\n\r\n\u003c!-- Include as many relevant details as possible about the environment you experienced the bug in --\u003e\r\n\r\n- CPython versions tested on: Python 3.11.2, 3.12.0alpha7, 3.12.0beta1\r\n- Operating system and architecture: Ubuntu 20.04 (AMD64)\r\n\r\n\u003c!--\r\nYou can freely edit this text. Remove any lines you believe are unnecessary.\r\n--\u003e\r\n\n\n\u003c!-- gh-linked-prs --\u003e\n### Linked PRs\n* gh-105231\n* gh-105234\n\u003c!-- /gh-linked-prs --\u003e\n","author":{"url":"https://github.com/domdfcoding","@type":"Person","name":"domdfcoding"},"datePublished":"2023-06-01T13:07:09.000Z","interactionStatistic":{"@type":"InteractionCounter","interactionType":"https://schema.org/CommentAction","userInteractionCount":4},"url":"https://github.com/105194/cpython/issues/105194"}
| route-pattern | /_view_fragments/issues/show/:user_id/:repository/:id/issue_layout(.:format) |
| route-controller | voltron_issues_fragments |
| route-action | issue_layout |
| fetch-nonce | v2:0615af67-543b-54fd-6290-5f8809a7702a |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | 9004:2A51AE:1D36DC:25C47B:6969A9D4 |
| html-safe-nonce | eb3cf090d5a0a8a0675780710ab2ebe6b99f7ca06532015b868675978137c439 |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI5MDA0OjJBNTFBRToxRDM2REM6MjVDNDdCOjY5NjlBOUQ0IiwidmlzaXRvcl9pZCI6IjI1NjI2ODI4MDY5MDIzMDMxODgiLCJyZWdpb25fZWRnZSI6ImlhZCIsInJlZ2lvbl9yZW5kZXIiOiJpYWQifQ== |
| visitor-hmac | 09be5e836841f2d1152f905a8619d40f1fc75f1bf7af5ac5109cdaebb5e618ed |
| hovercard-subject-tag | issue:1736295064 |
| github-keyboard-shortcuts | repository,issues,copilot |
| google-site-verification | Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I |
| octolytics-url | https://collector.github.com/github/collect |
| analytics-location | / |
| fb:app_id | 1401488693436528 |
| apple-itunes-app | app-id=1477376905, app-argument=https://github.com/_view_fragments/issues/show/python/cpython/105194/issue_layout |
| twitter:image | https://opengraph.githubassets.com/c333ef547be4c0c3dfbded60f26b0c5b544f5554b653c870da63c63efe7369c1/python/cpython/issues/105194 |
| twitter:card | summary_large_image |
| og:image | https://opengraph.githubassets.com/c333ef547be4c0c3dfbded60f26b0c5b544f5554b653c870da63c63efe7369c1/python/cpython/issues/105194 |
| og:image:alt | Bug report Between Python 3.12 alpha 7 and beta 1 the behaviour of format specifiers containing a backslash (e.g. \n, \u2603) in f-strings changed. Previously, the __format__ method would get e.g. ... |
| og:image:width | 1200 |
| og:image:height | 600 |
| og:site_name | GitHub |
| og:type | object |
| og:author:username | domdfcoding |
| hostname | github.com |
| expected-hostname | github.com |
| None | 24c4c97a2d520cb286b35e1a4c22d7a4df3c26a2fa28dd7cdf0e65db327b4de7 |
| turbo-cache-control | no-preview |
| go-import | github.com/python/cpython git https://github.com/python/cpython.git |
| octolytics-dimension-user_id | 1525981 |
| octolytics-dimension-user_login | python |
| octolytics-dimension-repository_id | 81598961 |
| octolytics-dimension-repository_nwo | python/cpython |
| octolytics-dimension-repository_public | true |
| octolytics-dimension-repository_is_fork | false |
| octolytics-dimension-repository_network_root_id | 81598961 |
| octolytics-dimension-repository_network_root_nwo | python/cpython |
| turbo-body-classes | logged-out env-production page-responsive |
| disable-turbo | false |
| browser-stats-url | https://api.github.com/_private/browser/stats |
| browser-errors-url | https://api.github.com/_private/browser/errors |
| release | 124667f43168afb6c9c03b7c02eb5b1d2e1be3d9 |
| ui-target | full |
| theme-color | #1e2327 |
| color-scheme | light dark |
Links:
Viewport: width=device-width