Skip to content

Different output from importlib.resources.files() in REPL in 3.12 versus 3.13 #121190

@danielhollas

Description

@danielhollas

Bug report

Bug description:

Running importlib.resources.files() without specifying the anchor parameter in interactive REPL in Python 3.12 raises a rather unhelpful error:

>>> import importlib.resources
>>> importlib.resources.files()
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/lib64/python3.12/importlib/resources/_common.py", line 45, in wrapper
    return func()
           ^^
  File "/usr/lib64/python3.12/importlib/resources/_common.py", line 56, in files
    return from_package(resolve(anchor))
           ^^
  File "/usr/lib64/python3.12/importlib/resources/_common.py", line 113, in from_package
    reader = spec.loader.get_resource_reader(spec.name)
                                             ^^
  File "/usr/lib64/python3.12/importlib/resources/_adapters.py", line 17, in __getattr__
    return getattr(self.spec, name)
           ^^
AttributeError: 'NoneType' object has no attribute 'name'

It would be nice to return something more helpful. The documentation doesn't mention that this function can raise, so I am assuming that raising AttributeError is not part of the public API?

However, on a locally built Python from current main branch, this call returns a path to Lib/_pyrepl. Even more surprising though is that this also happens when running the OLD REPL with TERM=dumb ./python

TERM=dumb ./python 
Python 3.14.0a0 (heads/main:1a84bdc237, Jun 30 2024, 21:44:46) [GCC 13.3.1 20240522 (Red Hat 13.3.1-1)] on linux
Type "help", "copyright", "credits" or "license" for more information.
warning: can't use pyrepl: terminal doesn't have the required clear capability
>>> import importlib.resources
>>> importlib.resources.files()
PosixPath('/home/hollas/software/cpython/Lib/_pyrepl')

CPython versions tested on:

3.12, CPython main branch

Operating systems tested on:

Linux

Linked PRs

Activity

lysnikolaou

lysnikolaou commented on Jul 1, 2024

@lysnikolaou
Member

Even more surprising though is that this also happens when running the OLD REPL with TERM=dumb ./python

TERM=dumb does not enable the old REPL. The env var is called PYTHON_BASIC_REPL.

danielhollas

danielhollas commented on Jul 1, 2024

@danielhollas
ContributorAuthor

TERM=dumb does not enable the old REPL. The env var is called PYTHON_BASIC_REPL.

Well, while it may not enable it explicitly, implicitly it does since pyrepl will not start with this type of terminal.

TERM=DUMB ./python 
Python 3.14.0a0 (heads/main:1a84bdc237, Jun 30 2024, 21:44:46) [GCC 13.3.1 20240522 (Red Hat 13.3.1-1)] on linux
Type "help", "copyright", "credits" or "license" for more information.
warning: can't use pyrepl: setupterm: could not find terminal
>>> import importlib.resources
>>> importlib.resources.files()
PosixPath('/home/hollas/software/cpython/Lib/_pyrepl')

But you are right that actually using PYTHON_BASIC_REPL will actually run the old REPL directly, and will produce the same behaviour as in 3.12

PYTHON_BASIC_REPL=1 ./python 
Python 3.14.0a0 (heads/main:1a84bdc237, Jun 30 2024, 21:44:46) [GCC 13.3.1 20240522 (Red Hat 13.3.1-1)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import importlib.resources
>>> importlib.resources.files()
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
    importlib.resources.files()
    ~~^
  File "/home/hollas/software/cpython/Lib/importlib/resources/_common.py", line 45, in wrapper
    return func()
  File "/home/hollas/software/cpython/Lib/importlib/resources/_common.py", line 56, in files
    return from_package(resolve(anchor))
  File "/home/hollas/software/cpython/Lib/importlib/resources/_common.py", line 116, in from_package
    reader = spec.loader.get_resource_reader(spec.name)
                                             ^^
  File "/home/hollas/software/cpython/Lib/importlib/resources/_adapters.py", line 17, in __getattr__
    return getattr(self.spec, name)
AttributeError: 'NoneType' object has no attribute 'name'
>>>

Note that I am not saying that the pyrepl behaviour is wrong here, just noting the difference. If anything, I'd change the behaviour in the old REPL so that at least it fails a bit more gracefully (not an obscure AttributeError).

whitphx

whitphx commented on May 22, 2025

@whitphx
Contributor

#134275 should fix the new REPL's different behavior than the old one,
while the issue below still is there

It would be nice to return something more helpful. The documentation doesn't mention that this function can raise, so I am assuming that raising AttributeError is not part of the public API?

added
stdlibStandard Library Python modules in the Lib/ directory
on May 23, 2025
whitphx

whitphx commented on Sep 5, 2025

@whitphx
Contributor

Hi from PyConTW sprint.

SpecLoaderAdapter accesses spec's attributes such as spec.name

return getattr(self.spec, name)

while spec can be None when the package is __main__ as documented.
return SpecLoaderAdapter(package.__spec__, TraversableResourcesLoader)

importlib.resources._common.from_package(package) needs to take care of the case where package.__spec__ is None.

Let me take a closer look...


>>> import importlib_resources
>>> importlib_resources.files()
Traceback (most recent call last):
  File "<python-input-1>", line 1, in <module>
    importlib_resources.files()
    ~~~~~~~~~~~~~~~~~~~~~~~~~^^
  File "/workspace/cpython/.venv/lib/python3.15/site-packages/importlib_resources/_adapters.py", line 17, in __getattr__
    return getattr(self.spec, name)
AttributeError: 'NoneType' object has no attribute 'name'
added a commit that references this issue on Sep 10, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Metadata

Metadata

Assignees

No one assigned

    Labels

    stdlibStandard Library Python modules in the Lib/ directorytopic-replRelated to the interactive shelltype-bugAn unexpected behavior, bug, or error

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions

      Different output from importlib.resources.files() in REPL in 3.12 versus 3.13 · Issue #121190 · python/cpython

      Follow Lee on X/Twitter - Father, Husband, Serial builder creating AI, crypto, games & web tools. We are friends :) AI Will Come To Life!

      Check out: eBank.nz (Art Generator) | Netwrck.com (AI Tools) | Text-Generator.io (AI API) | BitBank.nz (Crypto AI) | ReadingTime (Kids Reading) | RewordGame | BigMultiplayerChess | WebFiddle | How.nz | Helix AI Assistant