Lou said:
Robert Kern said:
I presume what you did was something like this:
from matplotlib import pylab
[N,x] = hist(eig, 10)
What you actually want is this:
from matplotlib import pylab
[N,x] = pylab.hist(eig, 10)
Or, if you're at the interactive prompt (but remember that it is inadvisable
to
do so in modules):
from matplotlib.pylab import *
[N,x] = hist(eig, 10)
You will probably want to review the section of the tutorial on importing
modules if you don't understand the differences.
Is pylab part of matplotlib?
Yes.
I always thought it was the other way
around. I have a similar view of numpy as part of scipy.
It is not.
Maybe I'm
confused on the dependencies. I find it confusing in the examples
sometimes when the "bigger" package is imported (e.g. scipy) and then a
"subpackage" is also imported. Like this:
from scipi import *
from scipi import numpy
The latter would definitely be bad form if it worked. numpy is a package all by
itself and should be imported by itself.
I know I've seen stuff like that, but I don't get it. The dependencies
are confusing to me.
pylab is a module provided with matplotlib that exposes a nice interface for
certain purposes. Somewhat confusingly, it is provided in two places, as its own
module:
import pylab
and as a submodule in the matplotlib package:
from matplotlib import pylab
Both do the same thing. You get to ask John Hunter if you want to know the whys
and wherefores.
numpy is a package all by itself. scipy is a package all by itself although it
depends on numpy being installed. You cannot import numpy from scipy. The
dependency of scipy on numpy does *not* entail that scipy will provide numpy in
its namespace.
Sometimes packages/modules are sloppy and accidentally expose the modules that
they import. For example, if you had a module foo.py like this:
import bar
def dostuff():
pass
then foo.py depends on bar.py. One *could* also do this:
from foo import bar
However, as I said, this would be bad form. It is an accident that the bar
module is exposed there. It should not be imported from the foo module.
Naturally, there are exceptions. Sometimes some other module is deliberately
imported and intended to be exposed in that place. Hopefully, there is a comment
to that effect explaining that it was intentional.
I did a search of the tutorial on 'import' but didn't find the answer.
It certainly doesn't answer your questions, but it should answer the OP's if my
presumptions are correct. Importing a module like so:
import mymodule
from mypackage import myothermodule
does not take all of symbols in mymodule and myothermodule and place them in the
current namespace.
http://docs.python.org/tut/node8.html
--
Robert Kern
"I have come to believe that the whole world is an enigma, a harmless enigma
that is made terrible by our own mad attempt to interpret it as though it had
an underlying truth."
-- Umberto Eco