回答編集履歴
2
修正
test
CHANGED
@@ -8,7 +8,7 @@
|
|
8
8
|
|
9
9
|
|
10
10
|
|
11
|
-
2年前の計算も、同じように-2した列
|
11
|
+
2年前の計算も、同じように-2した列でマージすればできるはずです。
|
12
12
|
|
13
13
|
|
14
14
|
|
1
プログラム変更
test
CHANGED
@@ -1,6 +1,6 @@
|
|
1
|
-
決算期の1年前を表す
|
1
|
+
決算期を表す数値の列と、そこから1をマイナスした列(1年前を表す)を作って、
|
2
2
|
|
3
|
-
その列
|
3
|
+
それらの列をキーに、自身をマージすると、1年前の売上高を同じ行に持って来れます。
|
4
4
|
|
5
5
|
|
6
6
|
|
@@ -8,7 +8,7 @@
|
|
8
8
|
|
9
9
|
|
10
10
|
|
11
|
-
2年前の計算も、同じように2
|
11
|
+
2年前の計算も、同じように-2した列とマージすればできるはずです。
|
12
12
|
|
13
13
|
|
14
14
|
|
@@ -32,15 +32,23 @@
|
|
32
32
|
|
33
33
|
|
34
34
|
|
35
|
-
|
35
|
+
# 決算期の数値化と1年前を表す列の追加
|
36
36
|
|
37
|
-
|
37
|
+
df2['Y'] = df2['決算期'].str[:-2].astype(int)
|
38
|
+
|
39
|
+
df2['Y_prev'] = df2['Y'] - 1
|
40
|
+
|
41
|
+
|
42
|
+
|
43
|
+
# 自身をmerge
|
44
|
+
|
45
|
+
df3 = df2.merge(
|
38
46
|
|
39
47
|
df2,
|
40
48
|
|
41
|
-
left_on=['証券コード', '企業名', '_prev', '決算期間'],
|
49
|
+
left_on=['証券コード', '企業名', 'Y_prev', '決算期間'],
|
42
50
|
|
43
|
-
right_on=['証券コード', '企業名', '
|
51
|
+
right_on=['証券コード', '企業名', 'Y', '決算期間'],
|
44
52
|
|
45
53
|
suffixes=(None, '_prev'),
|
46
54
|
|