回答編集履歴
1
1案目のコードに解説を追加
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
|
|