ループの中で取得したエクセルウィンドウごとに、リボンのボタンをクリックするには、下記のような方法があります。
まず、質問と同じように、フォルダ内のファイル取得~For each ループを作り、その中にExcelの起動を配置した状態を作っておきます。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/598ab16b-99cd-4466-9d13-e83e2b6dc625.jpeg)
ここで、処理対象のエクセルのうち、なんでもいいので1つ起動しておきます。
次に、PADで、アクションの検索ボックスに「ui」と入力し、「UIオートメーション」→「ウィンドウのUI要素をクリック」を選択します。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/6e457668-884b-4649-b407-d8646e08d793.jpeg)
「UI要素」の右にある「v」マークをクリックします。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/c07d89e6-6d91-4b05-98ed-02253e80e197.jpeg)
「UI要素の追加」ボタンをクリックします。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/c560d5dc-85f1-4507-aaa9-d52608882ab2.png)
※まだ追加されたUIがない場合(初回)は下の図の「UI要素の追加」ボタンをクリック。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/2889c307-940c-41e2-ba27-1a2863572a0f.jpeg)
別途起動しておいた処理対象エクセルの「校閲」タブを、コントロールを押しながら左クリックします。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/0abddeb9-59d8-4f2e-a779-4a04a313cad2.jpeg)
PADのダイアログに戻って「保存」をクリックします。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/17c2544c-6bd5-486f-897f-1e7f7fb1e91e.jpeg)
同様に、アクションから「UIオートメーション」→「ウィンドウのUI要素をクリック」を選び、「UI要素の追加」ボタンをクリック、
「校閲」タブの中の「シートの保護...」ボタンを、コントロールを押しながら左クリックします。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/d663e642-0919-4c4d-99ab-06b64c793709.jpeg)
同様に、PADに戻るので、「保存」ボタンをクリックします。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/be351c75-c2e9-4b91-b7e6-0d02d5c94c1c.jpeg)
(注意:少なくとも自分の環境では、「校閲」タブと「シートの保護...」を分けて追加しないとうまく動作しませんでした。「シートの保護...」ボタンを指定するだけでうまくいくかどうかは、環境依存である可能性があります)
ここからが重要です。
上まで終わったら、PADの右端の上のほうにある、縦に並んだメニューのうち、真ん中の、ダイヤ型が3つ重なったようなアイコンをクリックします。
(または、上部メニューの「表示」→「UI要素」を選択)
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/bc08be76-b531-4b49-bd5d-c433dc0693a3.jpeg)
そうすると、UIオートメーションで追加した要素の一覧が表示されます。
(もし以前から色々編集していたら、この部分はたくさんの部品が表示されているかもしれませんが、今回編集対象はこれまでの操作で作成された最新(一番下)のグループ、つまり
- □ Window~~~
- Tab item 「校閲」
- Button 'シートの保護...'
となっているグループになります)
「□Window...」となっている行にマウスカーソルを当てると、右に縦の3点マークが出るので、そのマークをクリックします。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/109fae57-511e-4ca4-b42e-ac00d7cb265a.jpeg)
「編集」をクリック。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/d96c5688-cc3e-4623-a975-97307a6f7059.jpeg)
右上の「テキストエディター」のスイッチをonにします。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/4a000987-4047-4d64-ba72-1b2ed42809dc.jpeg)
テキストエディタ―の「[x] 変数の選択」に書かれている内容を一旦削除し、下記をコピペして内容を置き換えてください。
(先頭の「:」も忘れずに、そのままコピペ)
:desktop > window[Name^="%CurrentItem.NameWithoutExtension%"][Process="EXCEL"]
↑の意味は「起動中のウィンドウから、CurrentItemの拡張子を除いたファイル名で始まるEXCELのウィンドウを検索して指定」という意味です。
(コピペ後の状態)
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/a1502cc9-8543-4539-984b-403ac7fb8037.jpeg)
コピペ後、「保存」をクリックします。
ここまでで、下の図の状態になっていればOKです。
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/3c4f665e-e425-481a-9816-ff60704e53d8.jpeg)
注意:2つの「ウィンドウのUI要素をクリック」がFor Eachの中にない場合は、2つを(「Tab Item '校閲'をクリックする」→「Button'シートの保護'をクリックする」の順番で) For Eachの中に入れてください。
これで、個別のエクセルウィンドウの"「シートの保護」ダイアログウィンドウの表示"までは自動化できました。
以降、「ウィンドウ内のテキストフィールドに入力する」以降の処理は、質問者さんがすでに指定しているやり方をそのまま行えば問題ないと思います。(「シートの保護」ダイアログウィンドウ自体のウィンドウ名は「シートの保護」固定であるため)
<サンプルの全体>
![イメージ説明](https://ddjkaamml8q8x.cloudfront.net/questions/2023-11-25/dde1bbf4-fa75-4a8e-8d64-b8bad9e4441b.jpeg)