PowerShell -Part 5

■ このスレッドは過去ログ倉庫に格納されています
2021/03/18(木) 00:29:52.04ID:/MpReTiX
前スレ
PowerShell -Part 4
https://mevius.5ch.net/test/read.cgi/tech/1577862511/

次スレは>>980が立ててね!!
703679
垢版 |
2021/11/07(日) 21:31:53.47ID:eC/ipH+D
脱線話になってしまうんですが、そもそもの国税庁の通達らしきものが全く流れてきていない中で
営業チラシとかからこの電子帳簿保存法の話を知って自分で調べている次第で…

で、調べてみると
https://www.nta.go.jp/law/joho-zeikaishaku/sonota/jirei/pdf/0021005-038.pdf
の2ページ目、検索要件として
「@取引年月日・取引先・金額で検索できること」
「A日付または金額の指定範囲検索」
「B2つ以上の任意の項目による検索」
とあり、そうなるとファイル名の命名規則に上記3項目を組み込み、
正規表現で検索する必要があるかな、という結論になったわけですが…

どうもこの2ページ目の※1に該当してABが不要になる可能性があり、
さらには
https://www.nta.go.jp/law/joho-zeikaishaku/sonota/jirei/pdf/0021006-031_06.pdf
の問12によると、そもそも既存のファイル管理だけしていれば検索機能要らないんじゃ…
というところに行きついたのが先週金曜の夜になります。

税理士に聞いても持ってる情報はこちらと大差なく、どう転んでいくか分からない状況 (;´д`)
2021/11/08(月) 00:13:47.57ID:bmKVlrQF
大変ですね。。。
税務署に問い合わせれば教えてくれるもんなんでしょうか?
2021/11/08(月) 00:23:43.73ID:bmKVlrQF
>>702
バックグラウンドで動かすのはstart-jobだけど、receive-jobしないといけないから、shと同じ雰囲気で動かすのは難しいんじゃないかな?
2021/11/08(月) 00:48:09.32ID:j5xrb+V9
>>705
ありがとう
諦める
2021/11/08(月) 01:18:37.98ID:bmKVlrQF
標準出力じゃなくてファイルに出力するなら、何も考えなくてよくて簡単なんですけどねぇ
2021/11/08(月) 14:40:09.96ID:ATC6W+sR
(echo foo &) | Receive-Job -Wait
709デフォルトの名無しさん
垢版 |
2021/11/08(月) 15:36:36.21ID:J2dLpPYS
配列にしてファイル名取得してコピーする動きさせたです
以下のようなイメージを浮かべていますが上手くいかなくてどう書いたらいいか有識者の方教えてください

$aaa[0]=〜.txt
$aaa[1]=〜.log
$aaa[2]=〜.sh

foreach($i in 0..2){
copy-item -force aaa[$i] $コピー先


$?で戻り値判定
710デフォルトの名無しさん
垢版 |
2021/11/08(月) 15:58:10.99ID:J2dLpPYS
自己解決したかも
下記でうまく動きましたわ頭悪い書き方かもしれないが

$aaa=@(ファイルパス,ファイルパス,ファイルパス)
$aaa | foreach-object { copy-item -force $aaa コピー先}
2021/11/08(月) 17:02:26.88ID:UsmHmtDw
パスの引数はliteralpath使った方がいいよ
普通のpathだとワイルドカードが有効になって面倒なことになる
712デフォルトの名無しさん
垢版 |
2021/11/08(月) 17:32:28.75ID:bmKVlrQF
literalpathを使った方が安全安心というのはその通りとして
戻り値チェックがなくなってるけど,それでよいのならこれでもいいんじゃないかと

foreach($i in ファイルパス,ファイルパス,ファイルパス){
copy-item -force $i コピー先
713デフォルトの名無しさん
垢版 |
2021/11/08(月) 17:45:54.79ID:J2dLpPYS
>>711
literalpath知りませんでした…
>>712
僕がしたかったのはその書き方です!そういう書き方の方が何してるのかわかりやすいと思うので

戻り値の件は書き損ねているだけなので大丈夫です
お二方ともご丁寧にどうもありがとうございます!
2021/11/08(月) 19:18:19.58ID:bmKVlrQF
[]*なんかはファイル名としては普通に使えるけどpowershellではワイルドカードとして扱われるんでliteralpath使うとよいです
2021/11/08(月) 20:03:51.47ID:Rlzdbs4L
さすがに * は使えないよ
2021/11/08(月) 21:40:49.31ID:Umd1M9Ks
*は使えないけど*は使える
<>は使えないけど<>は使える
つまり
717デフォルトの名無しさん
垢版 |
2021/11/08(月) 22:58:01.79ID:bmKVlrQF
>>715
ご指摘ありがとう
普通に間違えたw
2021/11/09(火) 09:20:55.86ID:6HgHkORr
v7.2.0
https://github.com/PowerShell/PowerShell/releases/tag/v7.2.0
PowerShell 7.2 の新機能
https://docs.microsoft.com/ja-jp/powershell/scripting/whats-new/what-s-new-in-powershell-72
2021/11/09(火) 18:10:17.23ID:m+qVFCof
>>703
YouTube に、ベストセラー『さおだけ屋はなぜ潰れないのか?』の著者・山田 真哉の動画がある

今現在も刻々と、変わり続けている
2021/11/09(火) 18:14:06.31ID:m+qVFCof
>>703
Libre Office を使えないの?

それで、何か問題でもあるのか?
721719
垢版 |
2021/11/09(火) 18:25:01.42ID:m+qVFCof
CSV なら、
VSCode の拡張機能・Rainbow CSV で、
RainBow Query Language(RBQL)とか、

GrapeCity のExcel Viewer などで、フィルター出来るのでは?
2021/11/10(水) 23:58:41.48ID:s7s2g3pi
Objectの配列ってあるやん?
例えばGet-childitemで返ってくるような奴。
こいつのあるプロパティの値で検索かけて、ヒットするオブジェクトを返してくれるコマンドレットってある?
2021/11/11(木) 07:34:27.20ID:rdUNi5nM
Where-Object
てかそれ知らなくても
Get-Childitem | %{ if($_.プロパティ -eq 'xxxx') $_ }
ってやればいいだけ
2021/11/11(木) 08:50:00.49ID:UywKMbXB
パイプラインからオブジェクトを削除する (Where-Object)
https://docs.microsoft.com/ja-jp/powershell/scripting/samples/removing-objects-from-the-pipeline--where-object-

PowerShell には、Where-Object コマンドレットがあります。これを使用すると、パイプラインの各オブジェクトをテストし、特定のテスト条件を満たしている場合にのみ、オブジェクトをパイプラインに沿って渡すことができます。 テストを通過しなかったオブジェクトは、パイプラインから削除されます。 テスト条件は、FilterScript パラメーターの値として指定します。
2021/11/11(木) 09:52:00.76ID:73eTlo3I
>>723
サンクス。
2021/11/11(木) 09:52:38.35ID:73eTlo3I
>>724
サンクス。
2021/11/11(木) 09:58:56.40ID:GzUsv1SA
プロパティの名前で検索するならこんな方法もありますよ

https://stackoverflow.com/questions/26997511/how-can-you-test-if-an-object-has-a-specific-property
2021/11/11(木) 13:58:48.12ID:AMbWD73B
質問です。

連想配列Aがあって、このAのkeyを要素とする配列Bがあります。
この配列Bの各要素の値のkeyを連想配列Aで対応するValueに全て置き換えたいのですがどうすれば良いでしょう?

新たに配列Cを作ってそこに置き換えた値を代入でもかまいません。

シンプルに出来れば良いのですが。
729728
垢版 |
2021/11/11(木) 14:20:34.82ID:7Xqdpo5k
重要な事書き忘れてました。

配列Bの要素にマッチする連想配列Aのkeyが存在しなければ、その配列の要素自体削除したい。
730デフォルトの名無しさん
垢版 |
2021/11/11(木) 14:30:48.53ID:GzUsv1SA
新規に$cを作ってよいのなら
PS C:\> $a = @{ a=1; b=2; c=3}
PS C:\> $b = @('a','b','c','d')
PS C:\> $c = @()
PS C:\> foreach ( $k in $b ) {
>> if ( $k -in $a.keys ) {
>> $c += $a[$k]
>> }
>> }
PS C:\> $c
1
2
3
PS C:\>

ではどうでしょう?
2021/11/11(木) 16:10:35.43ID:VwMpkHW9
>> if ( $k -in $a.keys ) {
>> $c += $a[$k]
keysで文字列の配列を作って更にそれを[]で検索して値を得る
って凄く無駄な気がするんだけど
KeyValuePairってPowerSellで使えないんだっけ
2021/11/11(木) 17:00:05.70ID:GzUsv1SA
getenumeratorでとれますね
733デフォルトの名無しさん
垢版 |
2021/11/11(木) 17:08:23.09ID:GzUsv1SA
valueが$nullではない,もしくは,valueが$nullの場合は$cに含めなくてもよいなら
ifの条件を( $null -ne $a[$k] )にできるね
$aの要素がたくさんあるならgetenumeratorでforeachを回して
$bから見つかった要素を削除するのがよいのかな?
2021/11/11(木) 22:45:45.51ID:opowWSFy
$a = @{a=1;b=2;c=3}
$b = @("a", "z", "c")
$c = $b | %{ $a[$_] }
これで出来てる?
2021/11/12(金) 01:15:10.90ID:M7lyd7nj
Ruby なら、配列同士の積を使える

hash = { "a"=>1, "b"=>2, "c"=>3 }

p hash.keys #=> ["a", "b", "c"]
p hash.values #=> [1, 2, 3]

ary_1 = [ "c", "x", "b" ]
p ary_2 = ary_1 & hash.keys #=> ["c", "b"]
736デフォルトの名無しさん
垢版 |
2021/11/12(金) 04:44:44.57ID:ZAoNN4kS
GetEnumerator使ったらこんな感じ
$a.GetEnumerator() |? {$_.key -in $b} | select -exp value
737デフォルトの名無しさん
垢版 |
2021/11/12(金) 04:50:17.45ID:ZAoNN4kS
これでも
$a.GetEnumerator() | &{process{if ($_.key -in $b) {$_.value}}}
2021/11/12(金) 16:12:33.21ID:xE6WDQNQ
やたら凝った回答が多いけど、素直に>>734でいいと思うんだが・・・
2021/11/12(金) 19:04:08.47ID:a3j0d+bF
だめじゃね?
$c[1] に $null が入るよ
仕様は
> 配列Bの要素にマッチする連想配列Aのkeyが存在しなければ、その配列の要素自体削除したい。
だし
2021/11/12(金) 19:19:41.08ID:0Z8rlyMb
$a.GetEnumerator() |?{$_.key -in $b} |% valueか
GetEnumeratorってすぐ忘れそうだけど補完で出てくるからいっか
2021/11/12(金) 19:38:43.32ID:ZAoNN4kS
おー、Foreach-Objectの短縮記法か
オシャレっすね
そう書けるのは知識として知ってるんだけど、全然出てきませんわ
Select-Object -ExpandProperty使っちゃう
2021/11/12(金) 19:54:08.84ID:a3j0d+bF
> valueが$nullの場合は$cに含めなくてもよい
が許されるなら
$a[$b] -ne $null
でいけそうだけどあとで何やってるのかわからなるなw
2021/11/12(金) 22:25:34.60ID:bmw0W+Zd
>>739
$nullは標準出力に出ないのか
配列のデフォルトの表示形式どうしてこうなった
$c -join ","とかで確認しないといけない
2021/11/12(金) 22:36:54.20ID:bmw0W+Zd
>>740
というか$a.GetEnumerator()から順序が考慮されないから正しい実装としては下記と思われる
$c = $b | ?{$a.contains($_)} | %{ $a[$_] }
2021/11/12(金) 23:08:41.99ID:ZAoNN4kS
730に戻ったね
2021/11/13(土) 00:03:49.31ID:IngrJLwZ
>>739
確認したから嘘だろと思ったら本当に入ってた・・・
表示されないのか

じゃあ途中でキーの有無を確認すればいいから、
$b | ?{ $a.ContainsKey($_) } | %{ $a[$_] }
でどうだろう。
「aのキーにあれば出力」をそのまま描いた感じ
2021/11/13(土) 00:04:11.42ID:IngrJLwZ
>>744でもう書かれてた
2021/11/13(土) 07:10:49.19ID:ugM6VKHw
順序気にするなら[ordered]を付ければいい
$a = [ordered]@{a=1;b=2;c=3}
2021/11/13(土) 12:11:25.74ID:DOOK67wF
質問よく見てないからかもしれんけど、$aの順序じゃなくて$bの順序を保証しないとだから意味ない
2021/11/13(土) 13:11:51.91ID:Z2vNsa/D
最初の質問も曖昧な点多くてグダグダになってる感
こんなんでいいか?

$a=@{a=1;b=2;c=3}
$b=@("a","z","c")
$c=[ordered]@{}
$b|? {$_ -in $a.keys}|% {$c[$_]=$a[$_]}
2021/11/13(土) 13:40:06.49ID:P6Qu4JtN
a 暗号解読用テーブル
b 暗号化された本文
て感じ?
2021/11/13(土) 14:05:31.30ID:DncAOgGY
>>750
元の$bと同じ単純配列が欲しいって書いてあるのにわざわざ連想配列作るとかグダグタになってるのはお前だけだろw
2021/11/15(月) 09:18:13.04ID:xJpmlO5M
>>750
チラ読みしただけだけど、キーの配列でテーブルを引きたいのなら、単に配列を添字にすればいいのでは?
$b[$a]
対応するキーが無いところはヌルが返る
2021/11/15(月) 09:24:47.63ID:xJpmlO5M
すぐ上に同じような事書いてたごめん>>742
valueが$nullな病的なケースまでは扱いたくないから知らん
2021/11/16(火) 08:21:35.56ID:lP4cPAw+
($b | %{ $a[$_] }) -ne $null が好きだな
-ne はこのための仕様なので合目的的
わかりにくさが不安ならコメントを添えてもいい
containsとアクセサでハッシュテーブルを2回ずつ検索するより好き
2021/11/17(水) 16:30:42.17ID:DmPYFyCr
>>755
結果は同じだけど定義通りじゃないのがな
存在しないキーの値がたまたまnullだった、フィルタしたら偶然求めたい値と一致したに過ぎない
既に言われてるけどValueがnullだと食い違う

やはりcontainsKeyが1番だと思う
パイプが連続してる方がシェルっぽくて見た目もかっこいいし
2021/11/17(水) 17:05:17.34ID:npYvnyKq
ああその違いがあったのか
でも発注者が本当に求めている条件がどっちなのかはかなり怪しい事例だと思う(言い訳)
2021/11/17(水) 18:52:13.63ID:80lHh4r4
>>756
存在しない値を参照するのは自分も抵抗ある
エラーで止まる可能性もあるしね
Powershellはそういうエラーは起こしにくいけど型付け言語ではアウトな気もする
2021/11/17(水) 20:15:51.70ID:ZRqEMafB
せめてベースの.NETと同じ方針にしてくり
2021/11/20(土) 14:03:27.82ID:mhCLQeY0
copy-itemでフォルダコピーする際、
サブディレクトリにあるフォルダ名やファイル名に特定の文字列 @("*hoge*","*huga*")
が含まれている場合除外したいのですが、
一通りググった方法を試しても上手くいきません。

get-childitemの有無等幾つか方法はあるみたいですが、どうやっても除外ができない。

上手くいく方法をご存知でしたら教えて頂けませんか。
2021/11/20(土) 14:19:09.90ID:brX6qPUI
robocopyを使う
2021/11/20(土) 14:29:08.15ID:foKEgqXu
>>760
Get-ChildItemでファイル列挙して正規表現かなんかでコピー対象のファイルなのか一個ずつ判定して一個ずつCopy-Itemすりゃいいんじゃないの
763デフォルトの名無しさん
垢版 |
2021/11/20(土) 14:39:59.37ID:ebQnhsZ6
除外より特定のに引っ掛ける方が楽じゃないか?
2021/11/20(土) 16:27:45.77ID:7hjyIAPL
>>760
そのフォルダだけじゃなく、

起点のフォルダ以下を、再帰的にすべてコピーするという意味か?
765sage
垢版 |
2021/11/20(土) 17:01:16.86ID:KK9A6rpv
>>760
以下みたいな感じでGet-ChildItemの出力にWhere-Objectに-notlikeでフィルタしてCopy-itemすればいい
-Recurse付けたがサブディレクトリ含めなければ外せばいい

Get-ChildItemとWhere-Objectを組み合わせてググれば他の活用も見つかるはず

Get-ChildItem -Recurse|
Where-Object {$_.Name -notlike "*foo*" -and $_.Name -notlike "*bar*"} |
ForEach-Object {Copy-Item $_.Fullname -Destination "出力先フォルダ" -Recurse}
766sage
垢版 |
2021/11/20(土) 17:24:30.70ID:KK9A6rpv
>>765
考えてみたらGet-ChildItem に -Recurseつけたら階層が再現しない
コピー元から階層で処理するならこのコードじゃ動かないわ
2021/11/20(土) 17:29:07.00ID:mhCLQeY0
皆様ありがとうございます。
頂いたアドバイスを受けて、正規表現を使ったりして試しているところです。
解決したら改めて報告します。

ちなみに要件としては、
「起点のフォルダを再起的に全てコピー(同じ階層構造)」となります。
2021/11/20(土) 17:35:03.97ID:mhCLQeY0
すみません、「起点のフォルダ以下を再起的に」ですね。
2021/11/20(土) 18:08:26.07ID:tZNHbLNh
>「起点のフォルダを再起的に全てコピー(同じ階層構造)」
パイプを繋げていくとこの点が不安になってくる。
コピー元のフルパスを正規表現で整形すれば良いだけだけど、何だかなって気分になる。
powershellが管理用途を目指したなら何でrobocopy相当の機能を提供しなかったんだろうか。
770sage
垢版 |
2021/11/20(土) 18:22:44.14ID:KK9A6rpv
起点のパスからパイプつなげて階層コピーとかやろうとすると大変なのね
Get-ChildItemだと起点パスからの相対パスが出てこないからこんな汚いコードしか作れなかったわ

Push-Location "コピー元パス"
Get-ChildItem -Recurse|
Where-Object {$_.Name -notlike "*foo*"} |
Where-Object {$_.Name -notlike "*bar*"} |
ForEach-Object {Copy-Item $_.FullName -Destination ("コピー先パス"+(Resolve-Path $_.FullName -Relative))}
2021/11/20(土) 19:23:56.73ID:ytLaGTl4
robocopyで十分ならrobocopy使うべき
2021/11/20(土) 19:24:28.43ID:ytLaGTl4
マルチスレッドで速いし
2021/11/20(土) 19:29:39.45ID:7hjyIAPL
https://stackoverflow.com/questions/32101358/copy-all-files-and-folders-except-few-in-ruby

Ruby では、Dir.glob("**/*") で再帰的に、起点フォルダ以下のすべてのファイルを配列に入れて、
そこから、コピーしないファイルを削除する

そして、再帰的にコピーする

FileUtils.cp_r( 配列, destination_folder )
2021/11/20(土) 21:10:31.67ID:ytLaGTl4
powershellでやるなら、一旦、まるっとコピーして、コピー先から不要なファイル消すのが簡単
2021/11/20(土) 22:41:40.55ID:foKEgqXu
面白そうだから作ってみた
.NETクラス使ったら負けというポリシーの人には受け入れられないかもしれんが

$SrcPath #コピー元
$DstPath #コピー先

[System.IO.Directory]::EnumerateFiles($SrcPath, "*", [System.IO.SearchOption]::AllDirectories) |
Where-Object { $_ -notlike "*foo*" } |
Where-Object { $_ -notlike "*bar*"} |
Select-Object @{Name = "FPath"; Expression = {$_} }, @{Name = "RPath"; Expression = {$_.SubString($SrcPath.Length)}} |
ForEach-Object { `
[System.IO.Directory]::CreateDirectory(([System.IO.Path]::GetDirectoryName($DstPath + $_.RPath))) | Out-Null; `
Copy-Item $_.FPath -Destination ($DstPath + $_.RPath) `
}
2021/11/21(日) 09:11:58.65ID:mz7l6eLz
わざわざ.NETクラス使った>>775は、>>770に比べてどんな良い事があるの?
2021/11/21(日) 10:22:51.55ID:GghqNAbU
.NETクラス使える俺スゲー君なんだろ
まあ $DstPath + $_.RPath なんて書いてるから中途半端な知識しかなさそうだけど
2021/11/21(日) 13:09:01.33ID:03fh42bF
>>777
Path.Combine使ってほしかったってこと?
2021/11/21(日) 13:14:19.30ID:03fh42bF
>>776
コピー先のフォルダーがあらかじめ作成されなくてもエラーにならないこと
2021/11/21(日) 14:06:02.04ID:/SaMuAE1
フォルダ名のファイルがあったらエラーになると思うけど
2021/11/21(日) 14:12:17.11ID:03fh42bF
>>780
それはエラーで正しい
2021/11/21(日) 15:37:22.85ID:rt6j8p0A
どうでもいいけど -notmatch 'foo|bar' でよくね
783デフォルトの名無しさん
垢版 |
2021/11/21(日) 23:12:49.29ID:ny8+2EkL
先日の質問者です。
下記コードで、想定通りの動作を確認しました。

事前に展開するディレクトリを作成する必要はありますが、
正規表現で抽出して、「Join-Path $DstPath $_.FullName.Substring($SrcPath.Length)」で
展開先ディレクトリに取得した要素を展開する感じです。

色々とアドバイス頂きありがとうございました。

---------------------------------------------------------------------------------
#出力先ディレクトリ
$SrcPath = 任意のディレクトリ

#出力先ディレクトリ(スクリプトの置き場 + 展開するディレクトリ)
$DstPath = Join-Path (Split-Path $MyInvocation.MyCommand.path) ("\test")

#抽出&コピー
Get-ChildItem -Recurse $SrcPath | ?{ $_.FullName -match "^(?!.*file)"} | `
Copy-Item -Destination {Join-Path $DstPath $_.FullName.Substring($SrcPath.Length)}
784デフォルトの名無しさん
垢版 |
2021/11/21(日) 23:14:57.70ID:ny8+2EkL
誤字が酷い・・・
以下の通り訂正します。

#コピー元ディレクトリ
$SrcPath = 任意のディレクトリ
2021/11/22(月) 01:24:51.37ID:DJE+GLbt
除外するのがファイルなら、全部コピーしてから消す方が、考える時間ノータイムでできるから、自分ならそうしちゃうな
ディレクトリ除外するなら素直にrobocopy使っちゃう
2021/11/22(月) 02:13:30.35ID:l3U7Q7kM
除外する理由も不明で全部コピーとか機械オンチかな
ストレージは有限リソースだぞ
2021/11/22(月) 02:45:11.19ID:49bPrPzL
Join-Pathのところ
$_.Fullname.replace($SrcPath,$DstPath)
でもよさそう
2021/11/22(月) 04:31:54.22ID:y2hovgGl
除外したいファイルが巨大ファイルかもしれないのに一旦コピーしてから削除とかアホやろ
2021/11/22(月) 10:05:58.61ID:xI4p9npJ
巨大ファイルかもしれないし小さいファイルかもしれない
質問者がまだ開示してない範囲なのでアイデアは言うだけタダだし叩くいわれもないだろう
2021/11/22(月) 10:12:16.38ID:xI4p9npJ
せっかく何でも呼べるシェルなのにrobocopyを呼ばない理由があるのかは知らん
純PSを使いたいという拘りは遊びや向学の範囲ならありだと思うけど
2021/11/22(月) 10:58:52.55ID:ssU9K32s
流石にコピーしてから削除は素人くさくて人には見せられないコードだな
792デフォルトの名無しさん
垢版 |
2021/11/22(月) 11:21:13.08ID:JeDQJ1PF
対象のファイル存在判定判定を行いたいんだけど
get-childitemで「〜が存在しない為検出できません」と表示されてFalseが返ってくる時と、対象ファイルはないけど何も表示されずにTrueが返ってくる時の違いって何でしょうか?

正規表現で複数のファイルを探してる時と限定して一つを探してる時の差って認識で合ってますでしょうか

認識が合ってるのであれば、Falseが返ってくる際のファイル存在判定ってどうやって行ったらいいですかね
2021/11/22(月) 11:32:08.25ID:y2hovgGl
>>792
Test-Path
2021/11/22(月) 11:57:50.46ID:vpaN3qMO
robocopyという既存で使えるコマンドがあることはわかりました。

しかし、それを承知の上で、純PowerShellのコマンドで実現できる方法を探していました。

ストレージにも容量があるため、抽出とコピーを同時に済ませたかった次第です。
2021/11/22(月) 12:33:14.41ID:DJE+GLbt
あ、やっぱスクリプト書くのが目的なんですね
それならそれでよいと思います
ぱぱっと仕事を済ませるために使えるものを使うのであれば
そういう考え方もあるってことで
もちろん、コピー不要なファイルのサイズが大きすぎたりしたときは使えませんが

ただ、エラー時のリトライとかマルチスレッドをpowershellで実装するのは面倒なのでrobocopyかrsync使うことをお勧めします
自分しかアクセスしない領域を扱うなら、ここに書かれていた例でも十分かと思います
796デフォルトの名無しさん
垢版 |
2021/11/22(月) 12:46:04.31ID:JeDQJ1PF
>>793
test-pathって複数ファイル判定できるのか?
797デフォルトの名無しさん
垢版 |
2021/11/22(月) 13:07:04.73ID:DJE+GLbt
test-pathはstring[]を引数に取れて、それぞれの判定結果を返しますね
2021/11/22(月) 13:52:50.70ID:jUHFyU9k
>>791
SSDを殺すツールでも作るのかね?
2021/11/22(月) 20:21:46.68ID:nGTeQ/fQ
仕事で使うならrobocopyだな
2021/11/22(月) 22:15:42.91ID:EOO8UMxm
今回の目的だとRobocopyで良いんだが
Powershellなら複数の条件のandでフィルターしたり正規表現でのフィルターやらリネームしながらのコピーとか活用シーンはあるわ
2021/11/23(火) 00:34:07.96ID:co/a4Nbp
>>787
大文字小文字の差異が発生したときにちゃんと動かないと思う
2021/11/23(火) 17:04:45.84ID:d0x80b5K
じゃあ -reprace 演算子で
2021/11/23(火) 20:11:06.49ID:LL+Lkvmb
せめて-creplaceと書いとけ
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況