RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1079155
Accepted
Alpensin
Alpensin
Asked:2020-02-06 20:03:25 +0000 UTC2020-02-06 20:03:25 +0000 UTC 2020-02-06 20:03:25 +0000 UTC

按源 DataFrame 转换为列表列表

  • 772

请告诉我这是如何以 Pandas 的风格精美完成的。到目前为止,我只能在可怕的周期的帮助下想象。初始数据:

import pandas as pd
import numpy as np
from datetime import datetime
data= {'ID': {0: 308, 1: 308, 2: 309, 3: 309},
 'LON': {0: 37.409936, 1: 37.409936, 2: 37.259936, 3: 37.259936},
 'LAT': {0: 55.967077, 1: 55.967077, 2: 55.997077, 3: 55.997077},
 'PERIOD_TIME': {0: datetime.strptime('2020-02-05 00:00:00', '%Y-%m-%d %H:%M:%S'),
  1: datetime.strptime('2020-02-05 01:00:00', '%Y-%m-%d %H:%M:%S'),
  2: datetime.strptime('2020-02-05 00:00:00', '%Y-%m-%d %H:%M:%S'),
  3: datetime.strptime('2020-02-05 01:00:00', '%Y-%m-%d %H:%M:%S')},
 'WEIGHT': {0: 0.1, 1: 0.9, 2: 0.4, 3: 0.5}}
df = pd.DataFrame(data)

df 看起来像这样:

ID  LON LAT PERIOD_TIME WEIGHT
0   308 37.409936   55.967077   2020-02-05 00:00:00 0.1
1   308 37.409936   55.967077   2020-02-05 01:00:00 0.9
2   309 37.259936   55.997077   2020-02-05 00:00:00 0.4
3   309 37.259936   55.997077   2020-02-05 01:00:00 0.5

需要创建一个单独的唯一 PERIOD_TIME 列表:

['2020-02-05 00:00:00', '2020-02-05 01:00:00']

以及来自数据的列表 [LON, LAT, WEIGHT]:

[[[37.409936, 55.967077, 0.1],[37.259936, 55.997077, 0.4]],
[[37.409936, 55.967077, 0.9],[37.259936, 55.997077, 0.5]]]
python
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Best Answer
    MaxU - stop genocide of UA
    2020-02-06T20:07:42Z2020-02-06T20:07:42Z

    可以这样做:

    In [50]: res = df.groupby("PERIOD_TIME")["LON","LAT","WEIGHT"].apply(lambda x: x.values.tolist())
    
    In [51]: res
    Out[51]:
    PERIOD_TIME
    2020-02-05 00:00:00    [[37.409936, 55.967077, 0.1], [37.25...
    2020-02-05 01:00:00    [[37.409936, 55.967077, 0.9], [37.25...
    dtype: object
    
    In [52]: res.iloc[0]
    Out[52]: [[37.409936, 55.967077, 0.1], [37.259936, 55.997077, 0.4]]
    

    或像这样:

    res = (df
           .assign(PERIOD_TIME=df["PERIOD_TIME"].astype(str))
           .groupby("PERIOD_TIME")
           ["LON","LAT","WEIGHT"]
           .apply(lambda x: x.values.tolist())
           .to_dict())
    
    In [58]: res
    Out[58]:
    {'2020-02-05 00:00:00': [[37.409936, 55.967077, 0.1],
      [37.259936, 55.997077, 0.4]],
     '2020-02-05 01:00:00': [[37.409936, 55.967077, 0.9],
      [37.259936, 55.997077, 0.5]]}
    
    • 3
  2. MarianD
    2020-02-06T20:13:11Z2020-02-06T20:13:11Z

    对于唯一的列表PERIOD_TIME:

    In[5]: lst = df["PERIOD_TIME"].drop_duplicates().to_list()
    In[6]: lst
    
    Out[6]: [Timestamp('2020-02-05 00:00:00'), Timestamp('2020-02-05 01:00:00')]
    
    In[7]: [ts.strftime("%Y-%m-%d %H-%M-%S") for ts in lst]
    
    Out[7]: ['2020-02-05 00-00-00', '2020-02-05 01-00-00']
    

    对于来自 data 的列表列表[LON, LAT, WEIGHT]:

    In[8]: df1 = df[["LON", "LAT", "WEIGHT"]].T
    In[9]: df1
    
    Out[9]: 
                    0          1          2          3
    LON     37.409936  37.409936  37.259936  37.259936
    LAT     55.967077  55.967077  55.997077  55.997077
    WEIGHT   0.100000   0.900000   0.400000   0.500000
    
    In[10]: [df1[i].to_list() for i in range(4)] 
    
    Out[10]: 
    [[37.409936, 55.967077, 0.1],
     [37.409936, 55.967077, 0.9],
     [37.259936, 55.997077, 0.4],
     [37.259936, 55.997077, 0.5]]
    
    • 2

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    如何从列表中打印最大元素(str 类型)的长度?

    • 2 个回答
  • Marko Smith

    如何在 PyQT5 中清除 QFrame 的内容

    • 1 个回答
  • Marko Smith

    如何将具有特定字符的字符串拆分为两个不同的列表?

    • 2 个回答
  • Marko Smith

    导航栏活动元素

    • 1 个回答
  • Marko Smith

    是否可以将文本放入数组中?[关闭]

    • 1 个回答
  • Marko Smith

    如何一次用多个分隔符拆分字符串?

    • 1 个回答
  • Marko Smith

    如何通过 ClassPath 创建 InputStream?

    • 2 个回答
  • Marko Smith

    在一个查询中连接多个表

    • 1 个回答
  • Marko Smith

    对列表列表中的所有值求和

    • 3 个回答
  • Marko Smith

    如何对齐 string.Format 中的列?

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5