Замените x-ticks с равномерно распределенными временными метками - PullRequest
0 голосов
/ 06 октября 2018

Я пытаюсь вставить timestamps на x-axis для scatter plot вместо total seconds.Ниже приведено то, что я пробовал до сих пор, но я получаю error с этой строкой;

loc, labels = ax.set_xticks(x)

AttributeError: 'NoneType' object has no attribute 'update'

Пример:

import pandas as pd
import matplotlib.pyplot as plt

d = ({
    'A' : ['08:00:00','08:10:00','08:12:00','08:26:00','08:29:00','08:31:00','10:10:00','10:25:00','10:29:00','10:31:00'],
    'B' : ['1','1','1','2','2','2','7','7','7','7'],     
    'C' : ['X','Y','Z','X','Y','Z','A','X','Y','Z'],
    })

df = pd.DataFrame(data=d)

fig,ax = plt.subplots()

x = df['A']
y = df['B']

x_numbers = (pd.to_timedelta(df['A']).dt.total_seconds())

ax.scatter(x_numbers, y)
loc, labels = ax.set_xticks(x)
newlabels = [str(pd.Timedelta(str(i)+ ' seconds')).split()[2] for i in loc]
ax.set_xticks(loc, newlabels)

Примечание Мне нужноиспользовать ax вместо plt, поскольку этот график называется subplot.Если я использую сюжет, axis будет назначен последнему subplot вместо назначенного.

Ответы [ 3 ]

0 голосов
/ 06 октября 2018

Я предполагаю, но если вы хотите заменить метки оси X, попробуйте.

import pandas as pd
import matplotlib.pyplot as plt

d = ({
    'A' : ['08:00:00','08:10:00','08:12:00','08:26:00','08:29:00','08:31:00','10:10:00','10:25:00','10:29:00','10:31:00'],
    'B' : ['1','1','1','2','2','2','7','7','7','7'],     
    'C' : ['X','Y','Z','X','Y','Z','A','X','Y','Z'],
    })

df = pd.DataFrame(data=d)
x = df['A']
y = df['B']
x_numbers = (pd.to_timedelta(df['A']).dt.total_seconds())

fig,ax = plt.subplots(figsize=(10,7))
ax.scatter(x_numbers, y)

xLabel = [str(int(num)) + ' seconds' for num in x_numbers]
ax.set_xticklabels(xLabel)

plt.tight_layout() 
plt.show()
0 голосов
/ 06 октября 2018

Я бы предложил использовать datetime напрямую, не шутя с метками.Кроме того, использование matplotlib.dates.MinuteLocator может дать вам хорошие позиции тиков.

import pandas as pd
import matplotlib.pyplot as plt
import matplotlib.dates as mdates

d = ({
    'A' : ['08:00:00','08:10:00','08:12:00','08:26:00','08:29:00','08:31:00',
           '10:10:00','10:25:00','10:29:00','10:31:00'],
    'B' : ['1','1','1','2','2','2','7','7','7','7'],     
    'C' : ['X','Y','Z','X','Y','Z','A','X','Y','Z'],
    })

df = pd.DataFrame(data=d)
df['A'] = pd.to_datetime(df['A'])

fig,ax = plt.subplots()

ax.scatter(df["A"].values, df["B"].values)
ax.set_xlim(df["A"].min(), df["A"].max())

ax.xaxis.set_major_locator(mdates.MinuteLocator((0,30)))
ax.xaxis.set_major_formatter(mdates.DateFormatter("%H:%M"))
plt.show()

enter image description here

0 голосов
/ 06 октября 2018

Примерно так будет работать: Edit: изменения, внесенные, чтобы убедиться, что ось и подзаговор используются

import pandas as pd
import matplotlib.pyplot as plt

d = ({
'A' : ['08:00:00','08:10:00','08:12:00','08:26:00','08:29:00','08:31:00','10:10:00','10:25:00','10:29:00','10:31:00'],
'B' : ['1','1','1','2','2','2','7','7','7','7'],     
'C' : ['X','Y','Z','X','Y','Z','A','X','Y','Z'],
})

df = pd.DataFrame(data=d)
fig,ax = plt.subplots()

x = df['A']
y = df['B']

x_numbers = (pd.to_timedelta(df['A']).dt.total_seconds())


ax.scatter(x_numbers, y)
plt.sca(ax) # gets handle on the current axis
loc, labels = plt.xticks()
plt.xticks(loc, [str(a) for a in x])
plt.show()
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...