回答編集履歴

1

訂正:追記

2018/04/12 02:53

投稿

mix-peach
mix-peach

スコア1910

test CHANGED
@@ -1,12 +1,8 @@
1
- Excelには計算式の計算を「自動」「手動」と設定が出来るところがあります。
1
+ ~~Excelには計算式の計算を「自動」「手動」と設定が出来るところがあります。
2
2
 
3
3
  これが「手動」になっていることが原因です。
4
4
 
5
-
6
-
7
5
  「数式」タブの中に「計算方法の設定」がありますので、これを自動にしてみてください。
8
-
9
-
10
6
 
11
7
  この設定は、ファイル単位ではなく、Excelそのものの設定なので
12
8
 
@@ -14,22 +10,74 @@
14
10
 
15
11
  計算式の入ったセルには「最後に保存された時に表示されていた値」が表示されるのです。
16
12
 
17
-
18
-
19
13
  例)計算方法が「手動」になっている場合
20
-
21
-
22
14
 
23
15
  A1 に 「あいうえおあ」 と設定し、
24
16
 
25
17
  B1 に 「=A1」 と入れたとします。
26
18
 
27
-
28
-
29
19
  B1 は、「式の入力直後」は 「あいうえお」 と表示されますが、
30
20
 
31
21
  このあとA1 の値をどんなに変更しても「再計算実行(これも数式タブにあります。F9でも実行できます)」を行わない限り、B1には「あいうえお」が表示されています。
32
22
 
23
+ ちなみに、「F2+Enter」はセルに式を入れ直したのと同じ動作なので、「式の入力直後」に値が表示されているだけです。~~
33
24
 
34
25
 
26
+
27
+ ---
28
+
29
+
30
+
31
+ 質問を勘違いしていたようなので、訂正と追記をします。
32
+
33
+
34
+
35
+ 元々の計算式の結果が「0」になることは、別問題ですが
36
+
35
- ちなみに、「F2+Enter」はセルに式を入れ直と同じ動作なので、「式入力直後」に値表示されていだけです
37
+ (計算式を、VBAで設定ているのであればそこらへんコードとかを掲載してもらえたら原因見つかかもです
38
+
39
+
40
+
41
+ とりあえず。
42
+
43
+
44
+
45
+ > 最後の処理でセルの書式を再定義するコードを追加(以下のソース)
46
+
47
+ > して結果を見ると、E6:G6セルは0000と表示され、数式バーの値は0、J5:AD5は1900/0/0と
48
+
49
+ > 表示され、数式バーの値も1900/0/0となっています。
50
+
51
+
52
+
53
+ は、
54
+
55
+ ```vba
56
+
57
+ r1.Value = r1.Value
58
+
59
+ ```
60
+
61
+ で 値の入れ直しているからです。
62
+
63
+
64
+
65
+ コードには、'結合セルの書式を再定義する とコメントが書かれていますが、
66
+
67
+ r1.valueで取得できるのは「値」です(計算式でも、書式でもないです)
68
+
69
+ そして、r1.valueに設定できるのは「値」です(計算式は入れられますが、書式は入れられません)
70
+
71
+
72
+
73
+ 元々の計算結果として表示されているのが「0」なので、
74
+
75
+ 「入っていた計算式」を、「表示している値=0」で上書しているので、動きとしてはいたって通常です。
76
+
77
+
78
+
79
+ なお、「E6:G6」のセルが「0000」になるのは、書式設定「その他」でさらに細かい設定が選べるはずなので、それが0000と表示されるように作用しているのではないでしょうか?
80
+
81
+
82
+
83
+ 「J5:AD5」は日付の初期を設定しているとのことですが、日付書式のセルに0を入れると「1900年1月0日」みたいな値になるのがExcelの仕様ですね。