Computer >> Máy Tính >  >> Lập trình >> Python

Python Pandas CustomBusinessHour - Kiểm tra xem dấu thời gian đã cho có được bù đắp hay không

Để kiểm tra xem dấu thời gian đã cho có được bù đắp hay không, hãy sử dụng CustomBusinessHour.is_on_offset () trong Pandas. Chuyển dấu thời gian làm đối số để kiểm tra.

Đầu tiên, hãy nhập các thư viện được yêu cầu -

import pandas as pd

Đặt đối tượng dấu thời gian trong Pandas -

timestamp = pd.Timestamp('2021-11-14 05:20:30')

Tạo phần bù CustomBusinessHour. CustomBusinessHour là lớp con của DateOffset -

cbhOffset = pd.tseries.offsets.CustomBusinessHour(start="09:30", end = "18:30")

Thêm phần bù vào Dấu thời gian và hiển thị Dấu thời gian đã cập nhật

print("\nUpdated Timestamp...\n",timestamp + cbhOffset)

Kiểm tra xem dấu thời gian đã cho có được bù đắp hay không -

offset = cbhOffset.is_on_offset(pd.Timestamp('2021-11-20 05:20:30'))

Hiển thị kết quả -

print("\nCheck if the given timestamp is on offset or not...\n",offset)

Ví dụ

Sau đây là mã -

import pandas as pd

# Set the timestamp object in Pandas
timestamp = pd.Timestamp('2021-11-14 05:20:30')

# Display the Timestamp
print("Timestamp...\n",timestamp)
# Create the CustomBusinessHour Offset
# CustomBusinessHour is the DateOffset subclass
# Here, "start" is the start time of your custom business hour in 24h format.
# The "end" is the end time of your custom business hour in 24h format.
cbhOffset = pd.tseries.offsets.CustomBusinessHour(start="09:30", end = "18:30")

# Display the CustomBusinessHour Offset
print("\nCustomBusinessHour Offset...\n",cbhOffset)

# Add the offset to the Timestamp and display the Updated Timestamp
print("\nUpdated Timestamp...\n",timestamp + cbhOffset)

# Check if the given timestamp is on offset or not
offset = cbhOffset.is_on_offset(pd.Timestamp('2021-11-20 05:20:30'))

# display the result
print("\nCheck if the given timestamp is on offset or not...\n",offset)

Đầu ra

Điều này sẽ tạo ra mã sau -

Timestamp...
 2021-11-14 05:20:30

CustomBusinessHour Offset...
 <CustomBusinessHour: CBH=09:30-18:30>

Updated Timestamp...
 2021-11-15 10:30:00

Check if the given timestamp is on offset or not...
 False