【发布时间】:2018-12-22 18:45:34
【问题描述】:
以下是我作为示例的数据框:
+--------------+-------+-------------+--------------+----------+-----------+
| ID | Part | RequestFrom | QTYRequested | Location | QTYOnHand |
+--------------+-------+-------------+--------------+----------+-----------+
| PartACity 1 | PartA | City 1 | 1 | LocA | 2 |
| PartACity 2 | PartA | City 2 | 1 | LocA | 2 |
| PartACity 3 | PartA | City 3 | 1 | LocA | 2 |
| PartACity 4 | PartA | City 4 | 1 | LocA | 2 |
| PartACity 5 | PartA | City 5 | 1 | LocA | 2 |
| PartACity 6 | PartA | City 6 | 1 | LocA | 2 |
| PartACity 7 | PartA | City 7 | 1 | LocA | 2 |
| PartACity 8 | PartA | City 8 | 1 | LocA | 2 |
| PartACity 9 | PartA | City 9 | 1 | LocA | 2 |
| PartACity 10 | PartA | City 10 | 1 | LocA | 2 |
| PartACity 1 | PartA | City 1 | 1 | LocB | 3 |
| PartACity 2 | PartA | City 2 | 1 | LocB | 3 |
| PartACity 3 | PartA | City 3 | 1 | LocB | 3 |
| PartACity 4 | PartA | City 4 | 1 | LocB | 3 |
| PartACity 5 | PartA | City 5 | 1 | LocB | 3 |
| PartACity 6 | PartA | City 6 | 1 | LocB | 3 |
| PartACity 7 | PartA | City 7 | 1 | LocB | 3 |
| PartACity 8 | PartA | City 8 | 1 | LocB | 3 |
| PartACity 9 | PartA | City 9 | 1 | LocB | 3 |
| PartACity 10 | PartA | City 10 | 1 | LocB | 3 |
| PartACity 1 | PartA | City 1 | 1 | LocC | 4 |
| PartACity 2 | PartA | City 2 | 1 | LocC | 4 |
| PartACity 3 | PartA | City 3 | 1 | LocC | 4 |
| PartACity 4 | PartA | City 4 | 1 | LocC | 4 |
| PartACity 5 | PartA | City 5 | 1 | LocC | 4 |
| PartACity 6 | PartA | City 6 | 1 | LocC | 4 |
| PartACity 7 | PartA | City 7 | 1 | LocC | 4 |
| PartACity 8 | PartA | City 8 | 1 | LocC | 4 |
| PartACity 9 | PartA | City 9 | 1 | LocC | 4 |
| PartACity 10 | PartA | City 10 | 1 | LocC | 4 |
+--------------+-------+-------------+--------------+----------+-----------+
我想把上面的dataframe变成这样:
+-------------+-------+-------------+--------------+----------+-----------+
| ID | Part | RequestFrom | QTYRequested | Location | QTYOnHand |
+-------------+-------+-------------+--------------+----------+-----------+
| PartACity 1 | PartA | City 1 | 1 | LocA | 2 |
| PartACity 2 | PartA | City 2 | 1 | LocA | 2 |
| PartACity 3 | PartA | City 3 | 1 | LocB | 3 |
| PartACity 4 | PartA | City 4 | 1 | LocB | 3 |
| PartACity 5 | PartA | City 5 | 1 | LocB | 3 |
| PartACity 6 | PartA | City 6 | 1 | LocC | 4 |
| PartACity 7 | PartA | City 7 | 1 | LocC | 4 |
| PartACity 8 | PartA | City 8 | 1 | LocC | 4 |
| PartACity 9 | PartA | City 9 | 1 | LocC | 4 |
+-------------+-------+-------------+--------------+----------+-----------+
如您所见,QTYOnHand 总数为 9,但 A 部分有 10 个未决请求。
我想找到一个更好的方法来分配数量。
由于LocA只有两个数量的PartA,所以我们只保留前两行。
LocB 有 3 个 PartA,接下来的 3 个将分配给 LocB。
LocC有4个PartA,接下来的4个将分配给LocC。
任何帮助将不胜感激!!!
【问题讨论】:
标签: python python-3.x python-2.7 pandas dataframe