On this page
matplotlib.axes.Axes.legend
Axes.legend(*args, **kwargs)
-
Places a legend on the axes.
To make a legend for lines which already exist on the axes (via plot for instance), simply call this function with an iterable of strings, one for each legend item. For example:
ax.plot([1, 2, 3]) ax.legend(['A simple line'])
However, in order to keep the “label” and the legend element instance together, it is preferable to specify the label either at artist creation, or by calling the
set_label()
method on the artist:line, = ax.plot([1, 2, 3], label='Inline label') # Overwrite the label by calling the method. line.set_label('Label via method') ax.legend()
Specific lines can be excluded from the automatic legend element selection by defining a label starting with an underscore. This is default for all artists, so calling
legend()
without any arguments and without setting the labels manually will result in no legend being drawn.For full control of which artists have a legend entry, it is possible to pass an iterable of legend artists followed by an iterable of legend labels respectively:
legend((line1, line2, line3), ('label1', 'label2', 'label3'))
Parameters: loc : int or string or pair of floats, default: ‘upper right’
The location of the legend. Possible codes are:
Location String Location Code ‘best’ 0 ‘upper right’ 1 ‘upper left’ 2 ‘lower left’ 3 ‘lower right’ 4 ‘right’ 5 ‘center left’ 6 ‘center right’ 7 ‘lower center’ 8 ‘upper center’ 9 ‘center’ 10 Alternatively can be a 2-tuple giving
x, y
of the lower-left corner of the legend in axes coordinates (in which casebbox_to_anchor
will be ignored).bbox_to_anchor :
matplotlib.transforms.BboxBase
instance or tuple of floatsSpecify any arbitrary location for the legend in
bbox_transform
coordinates (default Axes coordinates).For example, to put the legend’s upper right hand corner in the center of the axes the following keywords can be used:
loc='upper right', bbox_to_anchor=(0.5, 0.5)
ncol : integer
The number of columns that the legend has. Default is 1.
prop : None or
matplotlib.font_manager.FontProperties
or dictThe font properties of the legend. If None (default), the current
matplotlib.rcParams
will be used.fontsize : int or float or {‘xx-small’, ‘x-small’, ‘small’, ‘medium’, ‘large’, ‘x-large’, ‘xx-large’}
Controls the font size of the legend. If the value is numeric the size will be the absolute font size in points. String values are relative to the current default font size. This argument is only used if
prop
is not specified.numpoints : None or int
The number of marker points in the legend when creating a legend entry for a line/
matplotlib.lines.Line2D
. Default isNone
which will take the value from thelegend.numpoints
rcParam
.scatterpoints : None or int
The number of marker points in the legend when creating a legend entry for a scatter plot/
matplotlib.collections.PathCollection
. Default isNone
which will take the value from thelegend.scatterpoints
rcParam
.scatteryoffsets : iterable of floats
The vertical offset (relative to the font size) for the markers created for a scatter plot legend entry. 0.0 is at the base the legend text, and 1.0 is at the top. To draw all markers at the same height, set to
[0.5]
. Default[0.375, 0.5, 0.3125]
.markerscale : None or int or float
The relative size of legend markers compared with the originally drawn ones. Default is
None
which will take the value from thelegend.markerscale
rcParam
.markerfirst : bool
If True, legend marker is placed to the left of the legend label. If False, legend marker is placed to the right of the legend label. Default is True.
frameon : None or bool
Control whether the legend should be drawn on a patch (frame). Default is
None
which will take the value from thelegend.frameon
rcParam
.fancybox : None or bool
Control whether round edges should be enabled around the
FancyBboxPatch
which makes up the legend’s background. Default isNone
which will take the value from thelegend.fancybox
rcParam
.shadow : None or bool
Control whether to draw a shadow behind the legend. Default is
None
which will take the value from thelegend.shadow
rcParam
.framealpha : None or float
Control the alpha transparency of the legend’s background. Default is
None
which will take the value from thelegend.framealpha
rcParam
. If shadow is activated and framealpha isNone
the default value is being ignored.facecolor : None or “inherit” or a color spec
Control the legend’s background color. Default is
None
which will take the value from thelegend.facecolor
rcParam
. If"inherit"
, it will take theaxes.facecolor
rcParam
.edgecolor : None or “inherit” or a color spec
Control the legend’s background patch edge color. Default is
None
which will take the value from thelegend.edgecolor
rcParam
. If"inherit"
, it will take theaxes.edgecolor
rcParam
.mode : {“expand”, None}
If
mode
is set to"expand"
the legend will be horizontally expanded to fill the axes area (orbbox_to_anchor
if defines the legend’s size).bbox_transform : None or
matplotlib.transforms.Transform
The transform for the bounding box (
bbox_to_anchor
). For a value ofNone
(default) the Axes’transAxes
transform will be used.title : str or None
The legend’s title. Default is no title (
None
).borderpad : float or None
The fractional whitespace inside the legend border. Measured in font-size units. Default is
None
which will take the value from thelegend.borderpad
rcParam
.labelspacing : float or None
The vertical space between the legend entries. Measured in font-size units. Default is
None
which will take the value from thelegend.labelspacing
rcParam
.handlelength : float or None
The length of the legend handles. Measured in font-size units. Default is
None
which will take the value from thelegend.handlelength
rcParam
.handletextpad : float or None
The pad between the legend handle and text. Measured in font-size units. Default is
None
which will take the value from thelegend.handletextpad
rcParam
.borderaxespad : float or None
The pad between the axes and legend border. Measured in font-size units. Default is
None
which will take the value from thelegend.borderaxespad
rcParam
.columnspacing : float or None
The spacing between columns. Measured in font-size units. Default is
None
which will take the value from thelegend.columnspacing
rcParam
.handler_map : dict or None
The custom dictionary mapping instances or types to a legend handler. This
handler_map
updates the default handler map found atmatplotlib.legend.Legend.get_legend_handler_map()
.Notes
Not all kinds of artist are supported by the legend command. See Legend guide for details.
Examples
(Source code, png, pdf)
© 2012–2017 Matplotlib Development Team. All rights reserved.
Licensed under the Matplotlib License Agreement.
http://matplotlib.org/2.1.0/api/_as_gen/matplotlib.axes.Axes.legend.html