質問編集履歴
17
画像を追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)![イメージ説明]### 実現したいこと
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)![イメージ説明]### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
3
|
|
4
4
|
添付画像は
|
16
試したことにコード追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -153,6 +153,115 @@
|
|
153
153
|
「プロファイルの選択」からOKの後にメールが作成されるところまで行きました。
|
154
154
|
しかし本文や宛先には何も入っておらずアクティブなセルから取得したい値を取ることはできませんでした。
|
155
155
|
|
156
|
+
----------------------------------------------------------------------------------------------
|
157
|
+
「mymail.HTMLBody = strstyle」にしてSheet1に項目追加でメール文面に値が反映される(値がまちがっているが)ときのコード
|
158
|
+
|
159
|
+
'変数設定の指定
|
160
|
+
Option Explicit
|
161
|
+
|
162
|
+
Sub SendMail_HTML()
|
163
|
+
|
164
|
+
'シート設定
|
165
|
+
Dim ws1 As Worksheet
|
166
|
+
Set ws1 = Worksheets("Sheet1")
|
167
|
+
|
168
|
+
Dim ws2 As Worksheet
|
169
|
+
Set ws2 = Worksheets("Sheet2")
|
170
|
+
|
171
|
+
'Outlookアプリケーションを起動
|
172
|
+
Dim outlookObj As Outlook.Application
|
173
|
+
Set outlookObj = New Outlook.Application
|
174
|
+
|
175
|
+
|
176
|
+
|
177
|
+
'Outlookメールを作成
|
178
|
+
Dim mymail As Outlook.MailItem
|
179
|
+
|
180
|
+
|
181
|
+
'変数設定
|
182
|
+
Dim cmax As Long
|
183
|
+
Dim i As Long
|
184
|
+
Dim Companyname As String
|
185
|
+
Dim username As String
|
186
|
+
Dim mailaddress As String
|
187
|
+
Dim txt As TextStream
|
188
|
+
Dim honbun As String
|
189
|
+
Dim subject As String
|
190
|
+
Dim mailbody As String
|
191
|
+
Dim strstyle As String
|
192
|
+
Dim maxrow As Integer
|
193
|
+
Dim maker As String
|
194
|
+
Dim item As String
|
195
|
+
Dim model As String
|
196
|
+
Dim number As String
|
197
|
+
Dim unit As String
|
198
|
+
Dim duedate As String
|
199
|
+
|
200
|
+
'FileSystemObjectの設定
|
201
|
+
Dim fs As Scripting.FileSystemObject
|
202
|
+
Set fs = New Scripting.FileSystemObject
|
203
|
+
|
204
|
+
|
205
|
+
'メール作成
|
206
|
+
maxrow = Selection.Row
|
207
|
+
maker = ws1.Cells(maxrow, 6).Value '各列の値を取得
|
208
|
+
item = ws1.Cells(maxrow, 7).Value
|
209
|
+
model = ws1.Cells(maxrow, 8).Value
|
210
|
+
number = ws1.Cells(maxrow, 9).Value
|
211
|
+
unit = ws1.Cells(maxrow, 10).Value
|
212
|
+
duedate = ws1.Cells(maxrow, 12).Value
|
213
|
+
|
214
|
+
'Sheet2で条件に一致する行を取得
|
215
|
+
Dim foundRow As Range
|
216
|
+
Set foundRow = ws2.Range("M:M").Find(What:=maker, LookAt:=xlWhole)
|
217
|
+
|
218
|
+
If Not foundRow Is Nothing Then '条件に一致する行がある場合
|
219
|
+
Set mymail = outlookObj.CreateItem(olMailItem)
|
220
|
+
|
221
|
+
'プログラム12|メール情報と本文を取得
|
222
|
+
Companyname = ws2.Cells(foundRow.Row, 13).Value
|
223
|
+
username = ws2.Cells(foundRow.Row, 14).Value
|
224
|
+
mailaddress = ws2.Cells(foundRow.Row, 15).Value
|
225
|
+
mymail.BodyFormat = 2 'HTMLに変更
|
226
|
+
mymail.To = mailaddress
|
227
|
+
mymail.CC = ws2.Range("B3").Value 'cc宛先
|
228
|
+
mymail.BCC = ws2.Range("B4").Value 'bcc宛先
|
229
|
+
mymail.subject = ws2.Range("B5").Value '件名
|
230
|
+
honbun = Replace(Replace(Replace(Replace(Replace(Replace(Replace(Replace(Replace(ws2.Range("B6").Value, "{会社}", Companyname), "{名前}", username), "{メーカー}", maker), "{品目}", item), "{型番}", model), "{個数}", number), "{単位}", unit), "{納期}", duedate), vbLf, "<br>")
|
231
|
+
strstyle = "<font face=""游ゴシック (本文のフォント - 日本語)"" color=""&H000000"">" & honbun & "</font>"
|
232
|
+
mymail.HTMLBody = strstyle
|
233
|
+
|
234
|
+
|
235
|
+
'メール送信
|
236
|
+
mymail.Display 'メール表示(ここでは誤送信を防ぐために表示だけにして、メール送信はしない)
|
237
|
+
mymail.Save '下書き保存
|
238
|
+
'mymail.send 'メール送信
|
239
|
+
|
240
|
+
|
241
|
+
End If
|
242
|
+
'オブジェクト解放
|
243
|
+
Set mymail = Nothing
|
244
|
+
Set outlookObj = Nothing
|
245
|
+
|
246
|
+
'プログラム終了
|
247
|
+
End Sub
|
248
|
+
|
249
|
+
------------------------------------------------------------------------------------------------
|
250
|
+
「mymail.HTMLBody = strstyle」にしたがSheet1に項目追加していなくてメール文面に値が反映されないときのコード(文字数制限のため違うところのみ記載)
|
251
|
+
|
252
|
+
'メール作成
|
253
|
+
For i = 2 To cmax '2行目から最終行まで処理を繰り返す
|
254
|
+
maker = ws1.Cells(i, 6).Value '各列の値を取得
|
255
|
+
item = ws1.Cells(i, 7).Value
|
256
|
+
model = ws1.Cells(i, 8).Value
|
257
|
+
number = ws1.Cells(i, 9).Value
|
258
|
+
unit = ws1.Cells(i, 10).Value
|
259
|
+
duedate = ws1.Cells(i, 12).Value
|
260
|
+
Next
|
261
|
+
|
262
|
+
------------------------------------------------------------------------------------------------
|
263
|
+
|
264
|
+
|
156
265
|
### 補足情報(FW/ツールのバージョンなど)
|
157
266
|
|
158
267
|
ここにより詳細な情報を記載してください。
|
15
画像追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)![イメージ説明]### 実現したいこと
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)![イメージ説明]### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
3
|
|
4
4
|
添付画像は
|
14
画像追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)![イメージ説明]### 実現したいこと
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)![イメージ説明]### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
3
|
|
4
4
|
添付画像は
|
13
画像追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)![イメージ説明]### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
3
|
|
4
4
|
添付画像は
|
12
画像追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)### 実現したいこと
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
3
|
|
4
4
|
添付画像は
|
11
画像追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,5 +1,4 @@
|
|
1
|
-
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)![イメージ説明]
|
2
|
-
(https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/d43a9fc7-8ee4-4baf-b4c5-b6a97d0167ce.jpeg)### 実現したいこと
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)### 実現したいこと
|
3
2
|
よろしくお願い致します。
|
4
3
|
|
5
4
|
添付画像は
|
10
画像追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,5 @@
|
|
1
|
-
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)![イメージ説明]
|
2
|
+
(https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/d43a9fc7-8ee4-4baf-b4c5-b6a97d0167ce.jpeg)### 実現したいこと
|
2
3
|
よろしくお願い致します。
|
3
4
|
|
4
5
|
添付画像は
|
9
画像追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,5 +1,13 @@
|
|
1
|
-
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)### 実現したいこと
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
|
+
|
4
|
+
添付画像は
|
5
|
+
1枚目:Sheet1
|
6
|
+
2枚目:Sheet2
|
7
|
+
3枚目:Debag.printでhonbunを表示した画像
|
8
|
+
4枚目:メール作成した際に必要な情報が本文に反映されていない画像
|
9
|
+
5枚目:本文セルにセルの値を参照しようとした画像
|
10
|
+
|
3
11
|
・自動でOutlookメールを作成したい
|
4
12
|
・1シート目のアクティブセルの行のある列の値を2シート目のある列の中から探したい。
|
5
13
|
・2シート目のある列に同じ値がある場合は、その行のある列の値を取得して、2シート目内のあるセルの文章の中のある値に代入したい
|
8
画像追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)### 実現したいこと
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
3
|
・自動でOutlookメールを作成したい
|
4
4
|
・1シート目のアクティブセルの行のある列の値を2シート目のある列の中から探したい。
|
7
画像追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)### 実現したいこと
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
3
|
・自動でOutlookメールを作成したい
|
4
4
|
・1シート目のアクティブセルの行のある列の値を2シート目のある列の中から探したい。
|
6
画像追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)### 実現したいこと
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
3
|
・自動でOutlookメールを作成したい
|
4
4
|
・1シート目のアクティブセルの行のある列の値を2シート目のある列の中から探したい。
|
5
画像追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
### 実現したいこと
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-28/305b3c2f-9309-4c70-a680-8565870286ef.jpeg)### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
3
|
・自動でOutlookメールを作成したい
|
4
4
|
・1シート目のアクティブセルの行のある列の値を2シート目のある列の中から探したい。
|
4
一旦画像削除
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
|
1
|
+
### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
3
|
・自動でOutlookメールを作成したい
|
4
4
|
・1シート目のアクティブセルの行のある列の値を2シート目のある列の中から探したい。
|
3
試したことに追加。作成メールは立ち上がるようになったが値が入力されない
test
CHANGED
File without changes
|
test
CHANGED
@@ -125,6 +125,26 @@
|
|
125
125
|
outlookNamespace.Logon profileName:="プロファイル名", Password:="", ShowDialog:=False, NewSession:=False
|
126
126
|
。
|
127
127
|
|
128
|
+
追伸
|
129
|
+
下記の部分をコメントアウトするのと
|
130
|
+
'各シートの記載情報を取得
|
131
|
+
'cmax = ws1.Cells(Rows.Count, 1).End(xlUp).Row '最終行を取得
|
132
|
+
'If cmax = 1 Then Exit Sub 'データがなければ終了
|
133
|
+
|
134
|
+
Nextの位置をForの塊の下に持ってくると
|
135
|
+
'メール作成
|
136
|
+
For i = 2 To cmax '2行目から最終行まで処理を繰り返す
|
137
|
+
maker = ws1.Cells(i, 6).Value '各列の値を取得
|
138
|
+
item = ws1.Cells(i, 7).Value
|
139
|
+
model = ws1.Cells(i, 8).Value
|
140
|
+
number = ws1.Cells(i, 9).Value
|
141
|
+
unit = ws1.Cells(i, 10).Value
|
142
|
+
duedate = ws1.Cells(i, 12).Value
|
143
|
+
Next
|
144
|
+
|
145
|
+
「プロファイルの選択」からOKの後にメールが作成されるところまで行きました。
|
146
|
+
しかし本文や宛先には何も入っておらずアクティブなセルから取得したい値を取ることはできませんでした。
|
147
|
+
|
128
148
|
### 補足情報(FW/ツールのバージョンなど)
|
129
149
|
|
130
150
|
ここにより詳細な情報を記載してください。
|
2
画像を追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-27/48b393eb-8197-4565-a581-ab988ec92d5b.jpeg)### 実現したいこと
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-27/48b393eb-8197-4565-a581-ab988ec92d5b.jpeg)### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
3
|
・自動でOutlookメールを作成したい
|
4
4
|
・1シート目のアクティブセルの行のある列の値を2シート目のある列の中から探したい。
|
1
Excelの画像を追加
test
CHANGED
File without changes
|
test
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
### 実現したいこと
|
1
|
+
](https://ddjkaamml8q8x.cloudfront.net/questions/2023-04-27/48b393eb-8197-4565-a581-ab988ec92d5b.jpeg)### 実現したいこと
|
2
2
|
よろしくお願い致します。
|
3
3
|
・自動でOutlookメールを作成したい
|
4
4
|
・1シート目のアクティブセルの行のある列の値を2シート目のある列の中から探したい。
|