Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Python

Python Pandas - วิธีปัดเศษ TimeDeltaIndex ด้วยความถี่มิลลิวินาที


ในการปัดเศษ TimeDeltaIndex ด้วยความถี่มิลลิวินาที ให้ใช้ TimeDeltaIndex.round() กระบวนการ. สำหรับความถี่มิลลิวินาที ให้ใช้ ความถี่ พารามิเตอร์ที่มีค่า ‘ms’ .

ขั้นแรก นำเข้าไลบรารีที่จำเป็น -

import pandas as pd

สร้างวัตถุ TimeDeltaIndex เราได้ตั้งค่าข้อมูลที่เหมือนไทม์เดลต้าโดยใช้พารามิเตอร์ 'data' -

tdIndex = pd.TimedeltaIndex(data =['10 day 5h 2 min 3us 10ns', '+22:39:19.999999',
'2 day 4h 03:08:02.000045', '+07:20:32.261811624'])

แสดง TimedeltaIndex -

print("TimedeltaIndex...\n", tdIndex)

รอบการทำงานในวันที่ TimeDeltaIndex ด้วยความถี่มิลลิวินาที สำหรับความถี่มิลลิวินาที เราใช้ 'ms' -

print("\nPerforming round operation with milliseconds frequency...\n",
tdIndex.round(freq='ms'))

ตัวอย่าง

ต่อไปนี้เป็นรหัส -

import pandas as pd

# Create a TimeDeltaIndex object
# We have set the timedelta-like data using the 'data' parameter
tdIndex = pd.TimedeltaIndex(data =['10 day 5h 2 min 3us 10ns', '+22:39:19.999999',
'2 day 4h 03:08:02.000045', '+07:20:32.261811624'])

# display TimedeltaIndex
print("TimedeltaIndex...\n", tdIndex)

# Return a dataframe of the components of TimeDeltas
print("\nThe Dataframe of the components of TimeDeltas...\n", tdIndex.components)

# Round operation on TimeDeltaIndex date with milliseconds frequency
# For milliseconds frequency, we have used 'ms'
print("\nPerforming round operation with milliseconds frequency...\n",
tdIndex.round(freq='ms'))

ผลลัพธ์

สิ่งนี้จะสร้างรหัสต่อไปนี้ -

TimedeltaIndex...
TimedeltaIndex(['10 days 05:02:00.000003010', '0 days 22:39:19.999999',
'2 days 07:08:02.000045', '0 days 07:20:32.261811624'],
dtype='timedelta64[ns]', freq=None)

The Dataframe of the components of TimeDeltas...
   days hours minutes seconds milliseconds microseconds nanoseconds
0   10     5      2       0           0            3           10
1    0    22     39      19         999          999            0
2    2     7      8       2           0           45            0
3    0     7     20      32         261          811          624

Performing round operation with milliseconds frequency...
TimedeltaIndex([ '10 days 05:02:00', '0 days 22:39:20',
'2 days 07:08:02', '0 days 07:20:32.262000'],
dtype='timedelta64[ns]', freq=None)