Kod poniżej napisany w Pythonie importuje dane z Excela do Pythona, a następnie rysuje za pomocą matplotlib. Staram się wypełnić powyżej i poniżej linii 80 o różnych kolorach z wykorzystaniem funkcji fill_between
, ale dajefill_between daje "ValueError: rozmiary argumentów są niekompatybilne"
ValueError: Argument dimensions are incompatible
Uwaga: plik Excel ('eegg.xlsx'
) ma 4 kolumny z 682 wierszy i zawiera int
dane (0-100).
Myślę, że problem jest z argumentem where
wywołań , ale nie mogę tego rozwiązać.
import xlrd
import numpy
from datetime import time
from pylab import *
workbook = xlrd.open_workbook('eegg.xlsx')
worksheet = workbook.sheet_by_name('Sayfa1')
num_rows = worksheet.nrows - 1
num_cells = worksheet.ncols - 1
curr_row = -1
att=[]
med=[]
for i in [2,3]:
kolon = worksheet.col(i)
for x in kolon[1:]:
d= int(x.value)
if i==2:
att.append(d)
elif i==3:
med.append(d)
n = len(att)
X = np.linspace(0,n,n,endpoint=True)
Y1 = att
plot(X, Y1, color='blue', alpha=1.00)
fill_between(X, 0, Y1, (Y1) > 80, color='red', alpha=.25)
fill_between(X, 0, Y1, (Y1) < 80, color='blue', alpha=.25)
xlim(0,n), xticks([])
ylim(0,110), yticks([])
można wydrukować kształtów 'X' i' Y1'? Zrób 'print X.shape, Y1.shape'. –
Chociaż znajomość rodzaju zgłaszanego błędu może nam pomóc w rozwiązaniu problemu, byłoby to o wiele łatwiejsze, jeśli opublikujesz ** kompletny traceback **, ponieważ mówi nam to _ gdzie_ błąd jest podnoszony. – hooy