Matplotlib robi to domyślnie.
Na przykład:
import matplotlib.pyplot as plt
import numpy as np
x = np.arange(10)
plt.plot(x, x)
plt.plot(x, 2 * x)
plt.plot(x, 3 * x)
plt.plot(x, 4 * x)
plt.show()
Jak już zapewne wiesz, możesz łatwo dodać legendę:
import matplotlib.pyplot as plt
import numpy as np
x = np.arange(10)
plt.plot(x, x)
plt.plot(x, 2 * x)
plt.plot(x, 3 * x)
plt.plot(x, 4 * x)
plt.legend(['y = x', 'y = 2x', 'y = 3x', 'y = 4x'], loc='upper left')
plt.show()
Jeśli chcesz kontrolować kolory, które będą przełączane:
import matplotlib.pyplot as plt
import numpy as np
x = np.arange(10)
plt.gca().set_color_cycle(['red', 'green', 'blue', 'yellow'])
plt.plot(x, x)
plt.plot(x, 2 * x)
plt.plot(x, 3 * x)
plt.plot(x, 4 * x)
plt.legend(['y = x', 'y = 2x', 'y = 3x', 'y = 4x'], loc='upper left')
plt.show()
Jeśli nie znasz Matplotlib, samouczek jest dobrym miejscem do rozpoczęcia .
Edytować:
Po pierwsze, jeśli masz dużo (> 5) rzeczy, które chcesz narysować na jednej figurze, albo:
- Umieść je na różnych wykresach (rozważ użycie kilku podplotów na jednej figurze) lub
- Użyj czegoś innego niż kolor (np. Style znaczników lub grubość linii), aby je rozróżnić.
W przeciwnym razie skończysz z bardzo niechlujną fabułą! Bądź miły dla każdego, kto kiedykolwiek przeczyta cokolwiek robisz i nie próbuj wrzucać 15 różnych rzeczy do jednej postaci !!
Poza tym wiele osób jest w różnym stopniu ślepych na kolory, a rozróżnienie między wieloma subtelnie różnymi kolorami jest trudniejsze dla większej liczby osób, niż możesz sobie wyobrazić.
To powiedziawszy, jeśli naprawdę chcesz umieścić 20 linii na jednej osi w 20 stosunkowo różnych kolorach, oto jeden ze sposobów, aby to zrobić:
import matplotlib.pyplot as plt
import numpy as np
num_plots = 20
# Have a look at the colormaps here and decide which one you'd like:
# http://matplotlib.org/1.2.1/examples/pylab_examples/show_colormaps.html
colormap = plt.cm.gist_ncar
plt.gca().set_prop_cycle(plt.cycler('color', plt.cm.jet(np.linspace(0, 1, num_plots))))
# Plot several different functions...
x = np.arange(10)
labels = []
for i in range(1, num_plots + 1):
plt.plot(x, i * x + 5 * i)
labels.append(r'$y = %ix + %i$' % (i, 5*i))
# I'm basically just demonstrating several different legend options here...
plt.legend(labels, ncol=4, loc='upper center',
bbox_to_anchor=[0.5, 1.1],
columnspacing=1.0, labelspacing=0.0,
handletextpad=0.0, handlelength=1.5,
fancybox=True, shadow=True)
plt.show()
set_color_cycle
jest on przestarzały, więc ta linia powinna byćplt.gca().set_prop_cycle(plt.cycler('color', plt.cm.jet(np.linspace(0, 1, num_plots))))
i po prostu zmień jąplt.cm.YOUR_PREFERED_COLOR_MAP
w zależności od potrzeb.axes
) i zapytał o zmianę koloru pojedynczej linii na różnych wykresach (różneaxes
) ... To powiedziawszy, doskonała odpowiedź na ważne pytanie (być może inne niż to, które zadał OP, ale nikt nie może powiedzieć, ponieważ zadali to jedno pytanie i zniknęło!) - +1Ustawianie ich później
Jeśli nie znasz liczby działek, które zamierzasz wydrukować, możesz zmienić kolory po ich wykreśleniu, pobierając liczbę bezpośrednio z wykresu
.lines
, używając tego rozwiązania:Niektóre losowe dane
Potrzebny fragment kodu:
Wynik jest następujący:
źródło
TL; DR Nie, nie można tego zrobić automatycznie . Tak to mozliwe.
Każdy wykres (
axes
) na rysunku (figure
) ma swój własny cykl kolorów - jeśli nie wymusisz innego koloru dla każdego wykresu, wszystkie wykresy mają tę samą kolejność kolorów, ale jeśli rozciągniemy nieco, co oznacza „automatycznie” , to może być zrobione.OP napisał
Ale ... Matplotlib automatycznie generuje różne kolory dla każdej innej krzywej
Dlaczego więc wniosek OP? Jeśli nadal czytamy, to mamy
i ma to sens, ponieważ każda fabuła (każda
axes
w języku Matplotlib) ma swojącolor_cycle
(a raczej w 2018 r. swojąprop_cycle
), a każda fabuła (axes
) ponownie używa tych samych kolorów w tej samej kolejności.Jeśli takie jest znaczenie pierwotnego pytania, jedną z możliwości jest wyraźne nazwanie innego koloru dla każdej działki.
Jeśli wykresy (jak to często bywa) są generowane w pętli, musimy mieć dodatkową zmienną pętli, aby zastąpić kolor automatycznie wybrany przez Matplotlib.
Inną możliwością jest utworzenie obiektu cyklicznego
Zauważ, że
type(my_cycler)
jest,cycler.Cycler
aletype(actual_cycler)
jestitertools.cycle
.źródło
Chciałbym zaoferować niewielką poprawę w stosunku do ostatniej odpowiedzi w pętli podanej w poprzednim poście (ten post jest poprawny i nadal powinien zostać zaakceptowany). Domniemane założenie przyjęte podczas etykietowania ostatniego przykładu jest takie, że
plt.label(LIST)
wstawia numer XLIST
linii z linią odpowiadającą Xplot
wywołaniu czasu . Wcześniej miałem takie problemy. Zalecanym sposobem budowania legend i dostosowywania ich etykiet na podstawie dokumentacji matplotlibs ( http://matplotlib.org/users/legend_guide.html#adjusting-the-order-of-legend-item ) jest ciepłe poczucie, że etykiety idą wraz z dokładnymi działkami, które według nich wykonują:**: Matplotlib Legends nie działa
źródło