Squeak.ru - шаблоны программирования

Как перебирать часы данного дня в python?

У меня есть следующие данные временного ряда показаний температуры:

DT                Temperature
01/01/2019 0:00     41
01/01/2019 1:00     42
01/01/2019 2:00     44
......
01/01/2019 23:00    41
01/02/2019 0:00     44

Я пытаюсь написать функцию, которая сравнивает почасовое изменение температуры за данный день. Любое изменение, превышающее 3, увеличивает счетчик quickChange. Что-то вроде этого:

def countChange(day):
    for dt in day:
        if dt+1 - dt > 3: quickChange = quickChange+1

Я могу вызвать функцию на день, например: countChange(df.loc['2018-01-01'])



Ответы:


1

Используйте Series.diff со сравнением по 3 и подсчитайте значения Trues на sum:

np.random.seed(2019)

rng = (pd.date_range('2018-01-01', periods=10, freq='H').tolist() +
      pd.date_range('2018-01-02', periods=10, freq='H').tolist())
df = pd.DataFrame({'Temperature': np.random.randint(100, size=20)}, index=rng)  
print (df)
                     Temperature
2018-01-01 00:00:00           72
2018-01-01 01:00:00           31
2018-01-01 02:00:00           37
2018-01-01 03:00:00           88
2018-01-01 04:00:00           62
2018-01-01 05:00:00           24
2018-01-01 06:00:00           29
2018-01-01 07:00:00           15
2018-01-01 08:00:00           12
2018-01-01 09:00:00           16
2018-01-02 00:00:00           48
2018-01-02 01:00:00           71
2018-01-02 02:00:00           83
2018-01-02 03:00:00           12
2018-01-02 04:00:00           80
2018-01-02 05:00:00           50
2018-01-02 06:00:00           95
2018-01-02 07:00:00            5
2018-01-02 08:00:00           24
2018-01-02 09:00:00           28

#if necessary create DatetimeIndex if DT is column
df = df.set_index("DT")

def countChange(day):
    return (day['Temperature'].diff() > 3).sum()

print (countChange(df.loc['2018-01-01']))
4

print (countChange(df.loc['2018-01-02']))
9
04.12.2019
  • Спасибо, поскольку это сравнение с предыдущими часами, я также хотел бы рассмотреть отрицательное изменение. Итак, +3 и -3, как я могу это включить? 04.12.2019
  • @SakibShahriar - затем измените (day['Temperature'].diff() > 3).sum() на (day['Temperature'].diff().abs() > 3).sum() 04.12.2019

  • 2

    попробуйте pandas.DataFrame.diff:

    df = pd.DataFrame({'dt': ["01/01/2019 0:00","01/01/2019 1:00","01/01/2019 2:00","01/01/2019 23:00","01/02/2019 0:00"], 
                        'Temperature': [41, 42, 44, 41, 44]})
    
    df = df.sort_values("dt")
    df = df.set_index("dt")
    
    def countChange(df):
        df["diff"] = df["Temperature"].diff()
        return df.loc[df["diff"] > 3, "diff"].count()
    
    quickchange = countChange(df.loc["2018-01-01"])
    
    04.12.2019
    Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

    Веселье с прокси-сервером JavaScript
    Прокси-серверы JavaScript — это чистый сахар, если вы хотите создать некоторую общую логику в своих приложениях, чтобы облегчить себе жизнь. Вот один пример: Связь клиент-сервер Мы..

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...