回答編集履歴

1

1案目のコードに解説を追加

2017/04/09 06:26

投稿

copepoda
copepoda

スコア324

test CHANGED
@@ -1,6 +1,8 @@
1
1
  2案提示します。
2
2
 
3
3
 
4
+
5
+ ### 1案目
4
6
 
5
7
  1つ目は、最初に`locals()`組み込み関数を使用して、シンボルテーブル辞書を取得します。
6
8
 
@@ -19,6 +21,66 @@
19
21
  ```
20
22
 
21
23
 
24
+
25
+ ##### コードの解説
26
+
27
+ まず、`'df{}'.format(i + 1)` の format メソッドについては、以下のリンクを参照してください。
28
+
29
+
30
+
31
+ [str.format(*args, **kwargs)](https://docs.python.jp/3/library/stdtypes.html#str.format)
32
+
33
+ > 文字列の書式化操作を行います。このメソッドを呼び出す文字列は通常の文字、または、 {} で区切られた置換フィールドを含みます。それぞれの置換フィールドは位置引数のインデックスナンバー、または、キーワード引数の名前を含みます。返り値は、それぞれの置換フィールドが対応する引数の文字列値で置換された文字列のコピーです。
34
+
35
+
36
+
37
+ つまり、`'df{}'`の {} は、置換フィールドであり、引数で与えた`i + 1`の結果に置き換わります。
38
+
39
+
40
+
41
+ ```Python
42
+
43
+ print('df{}'.format(1)) # -> df1
44
+
45
+ print('df{}'.format(2)) # -> df2
46
+
47
+ print('df{}'.format(3)) # -> df3
48
+
49
+ ```
50
+
51
+
52
+
53
+ そして、`[locals_['df{}'.format(i + 1)] for i in range(1000)]`は、
54
+
55
+ 以下のコードと同様のことをリスト内包表記で記述しています。
56
+
57
+
58
+
59
+ ```Python
60
+
61
+ pd.concat([locals_['df1'], locals_['df2'], ..., locals_['df1000']])
62
+
63
+ ```
64
+
65
+
66
+
67
+ `locals_`は辞書であるため、[] を用いてキーから値を取得することができます。
68
+
69
+ 最初の `locals_['df1']` の結果は、df1 変数の値である DataFrame になります。
70
+
71
+
72
+
73
+ したがって、以下のコードと同じ結果が得られます。
74
+
75
+ ```Python
76
+
77
+ pd.concat([df1, df2, ..., df1000])
78
+
79
+ ```
80
+
81
+
82
+
83
+ #### 2案目
22
84
 
23
85
  2つ目は、最初からリストに各 df を追加していく方法です。
24
86