एक नंबर दिया, कैसे प्राप्त करने के लिए पिछले और अगले मूल्य एक सूची है? [बंद]

0

सवाल

मैं निम्नलिखित dataframe:

VALUE_TO_FIND  UNORDERED_LIST
5              [0,10]
3              [1,0,10,8,4,2]
2              [9,10,0]
5              [4,8,0,1,2,10]
4              [0,10,4]

मान दिया स्तंभ से VALUE_TO_FINDकैसे कर सकते हैं , मैं पिछले और अगले मान के अंदर UNORDERED_LIST?

VALUE_TO_FIND  UNORDERED_LIST   PREVIOUS_VALUE   NEXT_VALUE
5              [0,10]           0                10
3              [1,0,10,8,4,2]   2                4
2              [9,10,0]         0                9
5              [4,8,0,1,2,10]   4                8
4              [0,10,4]         4                4

ध्यान दें: UNORDERED_LIST हमेशा न्यूनतम और अधिकतम के VALUE_TO_FIND

dataframe pandas python
2021-11-24 02:55:34
1

सबसे अच्छा जवाब

1

वहाँ हो सकता है एक और अधिक कुशल समाधान है, लेकिन मैं करने की कोशिश की है zipपिंग दो प्रासंगिक कॉलम:

import pandas as pd
df = pd.DataFrame({'VALUE_TO_FIND': [5, 3, 2, 5, 4,],
    'UNORDERED_LIST': [[0,10], [1,0,10,8,4,2], [9,10,0], [4,8,0,1,2,10], [0,10,4],]})

def find_prev_next(x, lst):
    return max(y for y in lst if y <= x), min(y for y in lst if y >= x) # tuple

_ = [find_prev_next(x, lst) for x, lst in zip(df.VALUE_TO_FIND, df.UNORDERED_LIST)]
df['PREVIOUS_VALUE'], df['NEXT_VALUE'] = zip(*_)

print(df)
   # VALUE_TO_FIND       UNORDERED_LIST  PREVIOUS_VALUE  NEXT_VALUE
# 0              5              [0, 10]               0          10
# 1              3  [1, 0, 10, 8, 4, 2]               2           4
# 2              2           [9, 10, 0]               0           9
# 3              5  [4, 8, 0, 1, 2, 10]               4           8
# 4              4           [0, 10, 4]               4           4
2021-11-24 03:32:02

अन्य भाषाओं में

यह पृष्ठ अन्य भाषाओं में है

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................

इस श्रेणी में लोकप्रिय

लोकप्रिय सवाल इस श्रेणी में