python - 查找列表中每个元素之间的变化
问题描述
我有以下数组:
list1 = [2.11e-06, 2.03e-06, 2.24e-06, 2.04e-06, 3.01e-06, 1.62e-06, 1.82e-06, 1.67e-06, 1.75e-06, 1.67e-06, 1.71e-06, 1.69e-06, 1.87e-06, 1.75e-06, 1.75e-06, 1.75e-06, 1.85e-06, 1.75e-06, 2.03e-06, 1.78e-06, 1.93e-06, 1.75e-06, 1.75e-06, 1.75e-06, 2.19e-06, 2.28e-06, 2.13e-06, 2.92e-06, 2.14e-06, 2.24e-06, 2.06e-06, 2.21e-06, 2.17e-06, 2.17e-06, 2.41e-06, 2.41e-06, 2.03e-06, 2.42e-06]
我正在尝试获取一个新数组,其中每个元素都是一个元素与其下一个元素之间的变化。因此,例如,如果我有[1, 2, 1]
,我需要得到:[100, -50]
。
这是我尝试过的:
for x in list1[1:]:
PreviousIndex = list1.index(x)-1
Variation = ((x - list1[PreviousIndex])/list1[PreviousIndex])*100
NewArr.append(Variation)
这将给出以下输出:
[-12.8099173553719, -3.7914691943128, 10.344827586206902, -8.928571428571438, 47.54901960784314, -46.179401993355484, 12.345679012345679, -8.241758241758234, 4.790419161676638, -8.241758241758234, 2.395209580838313, -1.1695906432748548, 10.650887573964509, 4.790419161676638, 4.790419161676638, 4.790419161676638, 5.714285714285721, 4.790419161676638, -3.7914691943128, -12.315270935960598, 8.426966292134846, 4.790419161676638, 4.790419161676638, 4.790419161676638, 25.142857142857157, 4.109589041095889, -6.578947368421064, 37.08920187793427, -26.712328767123296, 10.344827586206902, -8.035714285714283, 7.281553398058244, -1.8099547511312237, -1.8099547511312237, 11.059907834101375, 11.059907834101375, -3.7914691943128, 19.211822660098527]
这个实现的问题是,在某个点上list1
,我有两个连续的相同元素1.75e-06, 1.75e-06
,所以我应该得到一个0.0
Variation,但我没有得到它。有谁知道这个简单问题的更流畅的实现?
解决方案
问题是这是列表中第一次出现list1.index(x)
的索引。如果您有重复,则以下值将获得第一个值的索引,您将多次使用该第一个值的前一个值。x
您可以改为按索引枚举数组。
list1 = [2.11e-06, 2.03e-06, 2.24e-06, 2.04e-06, 3.01e-06, 1.62e-06, 1.82e-06,
1.67e-06, 1.75e-06, 1.67e-06, 1.71e-06, 1.69e-06, 1.87e-06, 1.75e-06,
1.75e-06, 1.75e-06, 1.85e-06, 1.75e-06, 2.03e-06, 1.78e-06, 1.93e-06,
1.75e-06, 1.75e-06, 1.75e-06, 2.19e-06, 2.28e-06, 2.13e-06, 2.92e-06,
2.14e-06, 2.24e-06, 2.06e-06, 2.21e-06, 2.17e-06, 2.17e-06, 2.41e-06,
2.41e-06, 2.03e-06, 2.42e-06]
NewArr = []
for i in range(len(list1) -1 ):
prev = list1[i]
cur = list1[i+1]
Variation = ((cur-prev)/prev)*100
NewArr.append(Variation)
for i, item in enumerate(NewArr):
print(i, item)
您也可以这样做,numpy
一步将操作应用于整个数组:
arr = np.array(list1)
cur = arr[1:]
prev = arr[:-1]
new_arr = ((cur-prev)/prev) * 100
推荐阅读
- python - 带有 Apply 函数的 ValueError
- sql-server - 启动spring hibernate + jpa不返回数据库级别生成的列
- python - 如何检查日期列表是否包含某个月份
- java - 使用 Jackson 将不同类型反序列化为单个字段
- mapbox - Mapbox 自定义 SVG 标记和颜色属性
- python - 如何找到一列分类数据的模式?
- c++ - 什么时候增量发生在 C++ 的 for 循环中?
- c - 调用函数后以编程方式切换任务会导致奇怪的行为
- java - 扩展同一类的所有对象的方法?
- google-colaboratory - 如何将文件夹从一个 Google 团队驱动器复制到另一个