質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

コマンド

コマンドとは特定のタスクを行う為に、コンピュータープログラムへ提示する指示文です。多くの場合、コマンドはShellやcmdようなコマンドラインインターフェイスに対する指示文を指します。

コマンドプロンプト

コマンドプロンプト(cmd.exe)はMicrosoftによって提供されているコマンドラインインタプリタです。OS/2・Windows CE・Windows NTで使用可能です。

コマンドライン

コマンドライン(別名:Command Line Interface)は、ユーザに命令の入力を促す(プロンプト)文字列の表示を行い、すべての操作をキーボードを用いて文字列を打ち込む事でプログラムを走らせるユーザインターフェースです。

Q&A

解決済

1回答

2618閲覧

ピリオドが複数ついたファイル名をコマンドで一括置換したい

kirkir

総合スコア4

Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

コマンド

コマンドとは特定のタスクを行う為に、コンピュータープログラムへ提示する指示文です。多くの場合、コマンドはShellやcmdようなコマンドラインインターフェイスに対する指示文を指します。

コマンドプロンプト

コマンドプロンプト(cmd.exe)はMicrosoftによって提供されているコマンドラインインタプリタです。OS/2・Windows CE・Windows NTで使用可能です。

コマンドライン

コマンドライン(別名:Command Line Interface)は、ユーザに命令の入力を促す(プロンプト)文字列の表示を行い、すべての操作をキーボードを用いて文字列を打ち込む事でプログラムを走らせるユーザインターフェースです。

0グッド

0クリップ

投稿2020/09/29 06:27

編集2020/09/29 07:59

前提・実現したいこと

表題の通り、Windowsでピリオドが複数ついたファイル名をサブディレクトリのものも含め、コマンドで一括置換したいです。
「文字列.vnd.openxmlformats-officedocument.spreadsheetml.sheet」というファイルを「文字列.xlsx」に変換したいです。
文字列の長さはファイルによって異なっています。

試したこと

for /r /d %i in (*) do ren %i*.vnd.openxmlformats-officedocument.spreadsheetml.sheet *.xlsx
.sheetが.xlsxに変更されるのみで、それ以前が消えません。

補足情報(FW/ツールのバージョンなど)

Windows8

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

gentaro

2020/09/29 06:50

リネーム用のツールとか使えば正規表現が使えるので簡単にできると思いますが、コマンドラインにこだわりがあるんですか?
kirkir

2020/09/29 06:57

特にこだわりがあるわけではないのですが、コマンドについて学習中なので、もしコマンド・バッチファイルでできるのであれば知識として知っておきたいと思っております。
guest

回答1

0

ベストアンサー

文章とコードが合ってませんが、コードが正しいとして、

CMD

1for /r /d %i in (*) do ren %i.vnd.openxmlformats-officedocument.spreadsheetml.sheet %i.xlsx

で良いかと思います。

#追記
バッチファイルにしないと無理ですね。多分、これで。

CMD

1@echo off 2for /r /d %%i in (*) do for %%j in (%%i*) do call :SUB %%j 3exit /b 4 5:SUB 6echo %1 7set A=%~nx1 8ren %1 %A:.vnd.openxmlformats-officedocument.spreadsheetml.sheet=.xlsx%

念のため、renecho renに変えて確認してください。

投稿2020/09/29 06:59

編集2020/09/29 12:56
otn

総合スコア84499

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kirkir

2020/09/29 07:54

for /r /d %i in (*) do ren %i*.vnd.openxmlformats-officedocument.spreadsheetml.sheet *.xlsx でした。すみません。 上記に頂いたコマンドでは対象ファイルが見つからないと表示が出てしまいました。
otn

2020/09/29 09:07 編集

コードが正しいという前提が違いましたね。 ちゃんとコピペしましょう。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問