Getting module path string from a class instance

Steven D'Aprano steve+comp.lang.python at pearwood.info
Tue Nov 13 03:49:42 EST 2012


On Tue, 13 Nov 2012 07:54:32 +0000, Some Developer wrote:

> On 13/11/2012 07:19, Steven D'Aprano wrote:
>> On Tue, 13 Nov 2012 06:38:31 +0000, Some Developer wrote:
>>
>>> I'm trying to find a way to get a string of the module path of a
>>> class.
>>>
>>> So for instance say I have class Foo and it is in a module called
>>> my.module. I want to be able to get a string that is equal to this:
>>> "my.module.Foo". I'm aware of the __repr__ method but it does not do
>>> what I want it to do in this case.
>>>
>>> Can anyone offer any advice at all?
>> py> from multiprocessing.pool import Pool py> repr(Pool)
>> "<class 'multiprocessing.pool.Pool'>"
>>
>> Seems pretty close to what you ask for. You can either pull that string
>> apart:
>>
>> py> s = repr(Pool)
>> py> start = s.find("'")
>> py> end = s.rfind("'")
>> py> s[start+1:end]
>> 'multiprocessing.pool.Pool'
>>
>> or you can construct it yourself:
>>
>> py> Pool.__module__ + '.' + Pool.__name__ 'multiprocessing.pool.Pool'
>>
>>
> Yeah I considered doing it this way but was wary of that method because
> of possible changes to the implementation of the __repr__ method in the
> upstream code. If the Django developers don't consider the __repr__
> method a public API then it could change in the future breaking my code.

I didn't call SomeClass.__repr__. That is an implementation detail of 
SomeClass, and could change.

I called repr(SomeClass), which calls the *metaclass* __repr__. That is 
less likely to change, although not impossible.


If you're worried, just use the second way:

SomeClass.__module__ + '.' + SomeClass.__name__
 


> Of course this might not happen but I was hoping that there was a more 
> generic way of doing it that did not rely on a certain implementation 
> being in existence.

SomeClass.__name__ is the official way to get the name of a class; 
SomeClass.__module__ is the official way to get the name of the module or 
package it comes from.


-- 
Steven



More information about the Python-list mailing list