2015-11-20 45 views
2

我需要一个.csv文件的内容从转换:转换多个值列到新的键,值对

continent, region, country, 1990, 1991, 1992, 1993, ... 
Africa, East Africa, Ethiopia, 12, 14, 15, 9, ... 

到:

continent, region, country, year, value 
Africa, East Africa, Ethiopia, 1990, 12 
Africa, East Africa, Ethiopia, 1991, 14 
Africa, East Africa, Ethiopia, 1992, 15 
Africa, East Africa, Ethiopia, 1993, 9 
... 

还有一堆行的,所以这是不可能手工完成。我知道必须有一种方式来做到这一点,我真的只是有问题甚至解释我在做什么。它基本上是转换桌子的一部分,但不是全部。

编辑:这是一个完整的数据行的示例:

continent, region, country, country_abbr, economy, lat, long, 1990/91, 1991/92, 1992/93, 1993/94, 1994/95, 1995/96, 1996/97, 1997/98, 1998/99, 1999/00, 2000/01, 2001/02, 2002/03, 2003/04, 2004/05, 2005/06, 2006/07, 2007/08, 2008/09, 2009/10, 2010/11, 2011/12, 2012/13, 2013/14, 2014/15 
Africa, Middle Africa, Angola, AO, 7. Least developed region, -12.5, 18.5, 50, 79, 78, 33, 77, 62, 71, 64, 85, 55, 50, 21, 57, 38, 15, 25, 35, 36, 38, 13, 35, 29, 33, 35, 39 
+0

'year'的值当前是文件中的标题,'value'位于其下方的列中。这些话在技术上还不存在,我只需要对数据进行不同的编码。存在于我现有表格中的每一行都将变成25个新行(这是我拥有多少年)。 –

回答

1

不太清楚你的意思这些话在技术上并不只是存在之前尚未所以我提出country列第一年专栏,并且目前忽略country左侧的任何内容。 'Unpivot',详细描述如下here,并且选择country列到最后一列,并且只填充许多行。

生成的表应该是三列,每个国家有一组25行。第一列(“行” - 国名)可能用于查找我上面忽略的细节。