回答編集履歴

1

コメントした分を追記。

2019/09/26 02:22

投稿

suama
suama

スコア1997

test CHANGED
@@ -53,3 +53,73 @@
53
53
  fol.createFile(blobFile);
54
54
 
55
55
  ```
56
+
57
+
58
+
59
+ ### 追記
60
+
61
+
62
+
63
+ (コメントにも添えましたが追記します)
64
+
65
+ リネームはそこまで大変じゃなさそうなので、問題はメール本文から``Order No,************``を抽出するところですね。
66
+
67
+
68
+
69
+ (1) 未読メールを配列で取得 -> (2) ループで1つずつメールをチェック -> (3) さらにメールに添付ファイルがあればそれをループで処理、という流れかと思います。
70
+
71
+
72
+
73
+ (2)のところで、メールのbodyに対してパターンマッチで番号を取得してあげるといいとは思います。
74
+
75
+
76
+
77
+ クラスメソッド様の記事が近いかもしれませんので貼っておきます。
78
+
79
+ https://dev.classmethod.jp/etc/google-app-script-gmail-filter/
80
+
81
+
82
+
83
+ 試してないので、ほんとうに参考程度になりますが、こんなイメージです。
84
+
85
+
86
+
87
+ ```JavaScript
88
+
89
+ // メールの1メッセージに対しての処理
90
+
91
+ var body = message.getBody();
92
+
93
+ var OrdeNo = body.match(パターンマッチの文字列);
94
+
95
+
96
+
97
+ var attach = message.getAttachments();
98
+
99
+
100
+
101
+ // 添付ファイルを扱う部分のループ
102
+
103
+ for(var k = 0; k < attach.length; k++){
104
+
105
+ var blobFile = attach[k];
106
+
107
+ var originalName = blobFile.getName();
108
+
109
+ var newName = originalName + OrdeNo;
110
+
111
+ blobFile.setName(newName);
112
+
113
+
114
+
115
+ fol.createFile(blobFile);
116
+
117
+ }
118
+
119
+
120
+
121
+ ```
122
+
123
+
124
+
125
+ パターンマッチの書き方はそんなに難しくないと思います。慣れないうちは、まず ``body.match(/Order No,1234/)`` みたいに、ちゃんとメール本文に存在するオーダー番号を直書きして、正しく抽出できるかチェックしながら進めるといいと思います。