PowerShell -Part 6

■ このスレッドは過去ログ倉庫に格納されています
2022/02/13(日) 18:36:12.07ID:LaQ04ZoE
前スレ
PowerShell -Part 5
https://mevius.5ch.net/test/read.cgi/tech/1615994992/

次スレは>>980が立ててね!!
2022/02/22(火) 08:44:56.08ID:mFRfNBZm
Allow dragging files or folders into Terminal's Command Prompt window to display their path #12377
https://github.com/microsoft/terminal/issues/12377
2022/02/22(火) 20:22:44.35ID:wkvlg9SU
前スレの質問者に本当に必要だったものは、たぶんこういうのだと思うんだ…
class node {
[node]$val;
[node[]]$children;
}
2022/02/22(火) 20:24:23.06ID:wkvlg9SU
まちがえた→[object]$val

教えたがりおじさん見苦しい
2022/02/22(火) 21:34:19.39ID:5aCEOBVD
昔csvdeのエクスポートデータをVBSで木構造に変換したりしたけどその時はジャグ配列でなんとかなった
powershellだと配列に色々罠があるから大変そう
コマンドレット化されてるデータ構造を扱う事は得意でもテキストを1から解析して階層データとして扱うのには向かない気がする
2022/02/22(火) 22:00:01.99ID:LHZaRsEg
木のテキスト表現がカッコや""等ならbalancing groupでパースするのが便利だよ

perl/Pythonよりdotnetのパターン言語の方が強い(丸パクリだから当然だけど)
2022/02/22(火) 22:10:34.21ID:LHZaRsEg
組み込み型はスプラッターしちゃうとか罠多いから、内部でキッチリ階層持ちたいなら>>18みたいなロートルな手段が堅牢だったり

仕様覚えるという道もあるけど俺は諦めた
2022/02/22(火) 22:27:40.62ID:U3xoo538
逆説的だけど、.NETに詳しくない俺みたいな人ほどテキスト処理は抑えておくべき

なんか良く分からん物が返ってきても、オブジェクトの印字表現をOut-Fileで捕まえてテキスト処理にフォールバックできる()
2022/02/22(火) 22:59:38.55ID:LHZaRsEg
-match一発でパースが済まない木の表現は、段落を使って木を表現するyamlみたいなやつ
balancing group+複数行マッチで頑張れるかもしれないけど、地道にインデント数えてるわ
2022/02/22(火) 23:31:15.02ID:+zCOrMmD
一見不器用でもインデントレベルは素直に数えるのが正解
例えばpythonインタプリタもカウンタを使って構文をパースしてる

yaml系のシリアル化フォーマットは、インデントを数えるだけでパーサが書ける移植性が売り
2022/02/23(水) 20:35:53.13ID:KVH3xsak
Chromeでもパスワードにメモを付けて保存できるようになるみたいね
27915
垢版 |
2022/02/25(金) 01:33:26.38ID:wLKzA9jy
変数を文字列の中に入れ込んでしまって、消せないフォルダが出来てしまいました

C:\works\+ $a

削除もリネームもフォルダ移動すら出来ません
どうすれば削除出来ますでしょうか?
お知恵を貸してください
2022/02/25(金) 02:07:17.42ID:3hSRN4MI
ファイル名に$が入って、$aが展開されちゃう的な?ならエスケープすればいいだけでは
`$a
意図を汲めてるかちょっと自信ないけど
29915
垢版 |
2022/02/25(金) 07:49:52.49ID:wLKzA9jy
>>28

1. 変数を使ってフォルダを作ろうとした

2. 変数に値を代入した $a = 0225

3. C:\works\0225 を作りたかったので
“C:\works\ + $a” としたかったが
’C:\works\ + $a‘ としてしまった

4. + $a という名前のフォルダが
C:\works\ 直下に作られた

5. エクスプローラからもPowershellからも
+ $a と名前のついたフォルダは削除、リネーム、
移動が出来ない
C:\works\ + $a\test.txt のように+ $a フォルダ内に
ファイルを作る事は可能

Win10 Windows powershell 5.1 VSCODEで作成
細かい所はあまり覚えてませんがこんな感じです
2022/02/25(金) 08:55:58.66ID:Ex9z+jLY
うちの環境では削除できた
なんかのプロセスにロックされてるんじゃないの?
2022/02/25(金) 09:22:05.48ID:Ttq2k6xT
エラーメッセージを貼らない奴の相手してもしょうがない
32915
垢版 |
2022/02/25(金) 11:29:32.26ID:omaqMYjV
>>31
これは失礼しました
エラーは下記です。普通の名前のフォルダは削除出来ます

Remove-Item : 引数 '$null' を受け入れる位置指定パラメーターが見つかりません。
発生場所 行:1 文字:1
+ Remove-Item + $a
+ ~~~~~~~~~~~~~~~~~
+ CategoryInfo : InvalidArgument: (:) [Remove-Item]、ParameterBindingException
+ FullyQualifiedErrorId : PositionalParameterNotFound,Microsoft.PowerShell.Commands.RemoveItemCommand
33915
垢版 |
2022/02/25(金) 11:32:06.01ID:omaqMYjV
ちなみにフォルダを右クリックして出てくるプロパティ→セキュリティのタブには
「要求されたセキュリティ権限は利用できないか、または表示されません。」
とのエラーも出てます
2022/02/25(金) 11:40:38.52ID:Ttq2k6xT
>>32
> ’C:\works\ + $a‘ としてしまった
んなら

Remove-Item ’C:\works\ + $a‘
ってやれよ…
35915
垢版 |
2022/02/25(金) 12:06:55.57ID:omaqMYjV
>>34
すみません。。
やってみました

Remove-Item : パス 'C:\works\ + $a ' が存在しないため検出できません。
発生場所 行:1 文字:1
+ Remove-Item 'C:\works\ + $a '
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : ObjectNotFound: (C:\works\ + $a :String) [Remove-Item], ItemNotFoundException
+ FullyQualifiedErrorId : PathNotFound,Microsoft.PowerShell.Commands.RemoveItemCommand
2022/02/25(金) 12:16:43.02ID:SH4WT7RG
コマンドプロンプトを管理者権限で起動
rd /s /q エクスプローラーから対象フォルダをD&D

これで無理なら排他制御キャンセルするソフト使うかPCを一旦再起動
2022/02/25(金) 12:24:59.94ID:Ttq2k6xT
>>35
> Remove-Item : パス 'C:\works\ + $a '
$a の後ろの空白
38915
垢版 |
2022/02/25(金) 12:30:35.39ID:omaqMYjV
>>36
ありがとう御座います

「指定されたファイルが見つかりません」
と返されました。再起動も状況変わらず

Dirコマンドでは+ $a は表示されておりエクスプローラでも見えてるのですが何故か認識されないです
2022/02/25(金) 12:36:38.88ID:yKl3/QUV
コマンドで消したいだけならワイルドカードやタブ補完で選択すればいいじゃない

再起動後エクスプローラーから消せないか試したの?

何がしたいのか分からん
40915
垢版 |
2022/02/25(金) 12:42:21.42ID:omaqMYjV
>>37
空白で思い出しました
試行錯誤してて
'"C:\works\' + $a + '\"'
のような事もやってました

なので(なのかどうかも分かりませんが)フォルダの名前には + $a と後ろにも空白が入っています
41915
垢版 |
2022/02/25(金) 12:44:41.55ID:omaqMYjV
>>39
エクスプローラからの削除だと削除後も+ $a フォルダが残り続けます

やりたい事: + $a フォルダを削除したい
42915
垢版 |
2022/02/25(金) 12:48:15.22ID:omaqMYjV
追記正確なフルパス名
[]は半角スペースです

C:\works\[]+[]$a[]
2022/02/25(金) 12:55:42.52ID:SH4WT7RG
その親フォルダにカレントディレクトリを移動して他に$付くフォルダが無い、或いは削除してしまって良いなら
for /d %a in (*$*) do rd /s /q "%~a"
2022/02/25(金) 13:03:31.62ID:SH4WT7RG
もし>>43で駄目だったら最後のとこ
"%~sa"
を試してみて
2022/02/25(金) 13:04:14.85ID:AEqwOQnl
C:\worksごと消せばいい
46915
垢版 |
2022/02/25(金) 13:06:19.04ID:omaqMYjV
>>43
やはり指定されたファイルが見つかりませんと返されました

一旦整理します

目的︰ + $a フォルダを削除したい
環境:Win10, Win PS ver 5.1, Vscode 1.64.2

記述:'"C:\works\"[]+[]$y[]+[]"\"' (かなり記憶が曖昧)
フルパス C:\works\[]+[]$y[]
※[]は半角スペース

1. エクスプローラ
1.1 右クリック削除→削除後もフォルダが残り続ける
1.2 リネーム→「この項目は見つかりません。次の場所にはありません。」
1.3 移動→同上

2. PS
2.1 Remove-Item(\works直下)→「引数 '$null' を受け入れる位置指定パラメーターが見つかりません。」
2.2 Remove-Item(フルパス)→「 パス 'C:\works\ + $a ' が存在しないため検出できません。」

3. CMD
3.1 rd /s /q→「指定されたファイルが見つかりません」
47915
垢版 |
2022/02/25(金) 13:07:15.53ID:omaqMYjV
上記 $y → $a です
すみません
48915
垢版 |
2022/02/25(金) 13:10:23.66ID:omaqMYjV
>>44
saでも変わらずでした

>>45
>>46の1.1と同じでした
2022/02/25(金) 13:11:33.74ID:AEqwOQnl
フォルダが消したいだけならPowershell関係ないからこちらでどうぞ

Windows 10 質問スレッド Part82
https://mevius.5ch.net/test/read.cgi/win/1644831539/
2022/02/25(金) 13:17:48.06ID:MEIpOner
\\?\C:\fogo
2022/02/25(金) 15:04:10.02ID:gazry23L
>>47
> 上記 $y → $a です
> すみません
だからさあ、入力した内容とエラーメッセージをそのまま貼ってくれよ…
2022/02/25(金) 20:57:30.79ID:FVUZxr5Y
dir "*a*" などとして対象のフォルダだけ表示されることを確認して
dir "*a*" |
2022/02/25(金) 20:58:43.73ID:FVUZxr5Y
dir "*a*" | % {remove-item -LiteralPath $_.Name}
でどうだろうか
2022/02/25(金) 21:06:53.72ID:zbdaU1gm
dir /x
で8.3形式のファイル名があるなら、それで消してみる
だめなら、>>50の形式でフルパスを指定する
55915
垢版 |
2022/02/26(土) 12:47:40.66ID:AL/cEm3C
ありがとうございます。
レス遅くなりました。以下のように返ってきました。
>>53で出てきたフォルダ名+[]$aと末尾に半角スペースが見えません。
見えない文字が埋め込まれている可能性はありますでしょうか?

>>52
dir : 項目 C:\works\ + $a が見つかりませんでした。
発生場所 行:1 文字:1
+ dir "*a*"
+ ~~~~~~~~~
+ CategoryInfo : ObjectNotFound: (C:\works\ + $a :String) [Get-ChildItem], IOException
+ FullyQualifiedErrorId : ItemNotFound,Microsoft.PowerShell.Commands.GetChildItemCommand

>>53
dir : 項目 C:\works\ + $a が見つかりませんでした。
発生場所 行:1 文字:1
+ dir "*a*" | %{remove-item -LiteralPath $_.name}
+ ~~~~~~~~~
+ CategoryInfo : ObjectNotFound: (C:\works\ + $a :String) [Get-ChildItem], IOException
+ FullyQualifiedErrorId : ItemNotFound,Microsoft.PowerShell.Commands.GetChildItemCommand
56915
垢版 |
2022/02/26(土) 12:47:51.62ID:AL/cEm3C
>>54
ドライブ C のボリューム ラベルは Windows です
ボリューム シリアル番号は AE2C-1EB8 です

C:\works\ のディレクトリ

2022/02/23 16:50 <DIR> + $a
2022/02/25 10:55 <DIR> .
2022/02/25 10:55 <DIR> ..
0 個のファイル 0 バイト
3 個のディレクトリ 1,144,323,043,328 バイトの空き領域

>>50
使い方が分からず試せてません
2022/02/26(土) 13:19:35.91ID:zbGeAZZp
Win10の質問スレ行けって言ったのに何故行かないのかな?
powershellに拘る理由がわからないよ

仕方ないのでこっちで回答するわ
Poweshell関係ないけど

https://itojisan.xyz/パソコンのトラブル/windows10でフォルダ・ファイルを削除できない/

これ全部試せ
2022/02/26(土) 13:34:00.21ID:DA2+bsLA
これ本来含まれないはずの+が含まれてるから消さないんでしょ

ディスクエディタかなんかで強制的に消せる名前にリネームするしかないのでは?
(FAT時代にしかやったことないからNTFSでできるかは知らん)

曖昧な記憶のスクリプトを正確に思い出せればなんとかなるやもしれんが
普通の方法では+がファイル名かフォルダ名の一部と解釈されないから消すのは無理だと思う
なかなかコーナーケースのバグ見つけたなw

多分PSでどうこうできる領域じゃない
再インストールが一番早いかもw
2022/02/26(土) 13:36:55.01ID:+OtunY2h
当てずっぽうで試す前に、まずabout_Quoting_Rulesを読んでくれ
何かおかしい文字が入ってるのかは、[byte[]]にキャストすれば分かるから
それ見て正しくクオートして入力してくれ
2022/02/26(土) 14:08:05.70ID:+OtunY2h
>>58
+を特別扱いするのはNTFSじゃなくて、特定のコマンドの仕様では?(copy fi+le等)
色んなコマンドが内部で引いてる可能性があるから避けたほうが無難な文字とは思うけど
$もNTFS的には合法だけど、予約名のプレフィックスにする慣習なので、なので避けたほうがいいのは確か
undocumentedなのもいっぱいある
2022/02/26(土) 14:54:37.65ID:+OtunY2h
win10/pwsh7.2.0/NTFSで試してみた

> ni -d sandbox |sl
> echo valid? >'+ $a'
> gci |select name
Name
----
+ $a
> ri '+ $a' &&echo $?
True
> gci |select name
# no output

うーん?
2022/02/26(土) 15:18:46.03ID:1IWc50so
cmdを起動して
rd "\\.\C:\works\ + $a "
2022/02/26(土) 15:22:25.68ID:1IWc50so
ダメなら引用符ありなしと、//./ と //?/ を変化させて試してみて
2022/02/26(土) 15:46:10.03ID:EUVpr27z
検証した
cmdを起動して rd "\\?\C:\works\ + $a " が正解だった
このやり方はPowershell経由では消えない
末尾スペースが再現できなかったから md "\\?\C:\works\ + $a " で作った
65915
垢版 |
2022/02/26(土) 16:01:12.94ID:AL/cEm3C
>>62
>>64
消えました!!凄い!!!
ご教示頂きました皆さん本当にありがとうございます!
66915
垢版 |
2022/02/26(土) 16:04:31.69ID:AL/cEm3C
因みに rd “\\?\〜“ってどんな意味でしょうか?
2022/02/26(土) 16:07:54.37ID:EUVpr27z
文字列解析を無効化する名前空間
https://docs.microsoft.com/ja-jp/windows/win32/fileio/naming-a-file#maximum-path-length-limitation
2022/02/26(土) 16:49:18.98ID:+OtunY2h
ずこー
ファイル名に末尾スペースはNTFS的に非合法のはずなのに、なんで作れちゃうかな
闇が深い
2022/02/26(土) 16:54:25.81ID:+OtunY2h
一応補足しとくとシェルは関係ない、pwshから非合法パス名へアクセスするのにも(ri)Remove-Item "\\?\~"は使える(使えてしまう)
2022/02/26(土) 19:13:10.48ID:kQiC9zng
-LiteralPathが多分必要
2022/02/26(土) 20:14:14.01ID:+OtunY2h
ri -lp '\\?\C:\Users\ore\sandbox\trailing 'で消せた
そもそも-literalpath指定無しには正しくない名前のファイルは作れないようになってる

標準のFileSystemプロバイダは静かに切り詰めるようだけど、できればエラーにしてほしいところ
2022/02/26(土) 20:16:53.67ID:+OtunY2h
当たり前だがext4上では合法だから普通に作れるな
プロバイダ依存きをつける
2022/02/26(土) 20:28:51.97ID:HRmzshO4
各々のプログラムのモラルに任せられてるのが残念なところ
pwshからコマンドレットを使う限りはうっかり変なもの作るの阻止してくれるのが救いか

linux/mac上ならそもそもOSがハネてくれるのでpwshで余計なチェック挟む必要もないのだけど
2022/02/26(土) 20:33:36.43ID:7VK+waus
Mac特有の濁点ユニコードもそのまま入るし互換性のためだろう
2022/02/26(土) 20:34:30.39ID:HRmzshO4
いや
>>29によるとコマンドレットで作れてしまったのか
それはちょっとまずい気がする
2022/02/26(土) 23:23:38.20ID:U2u/902M
いや真似しても普通には再現できなかったよ
\\?\ でなんとか作った
条件もわからんしいたずらに憂いてもしょうがない
2022/02/28(月) 02:46:56.51ID:RHAmUG8r
APIで普通に作れるから対策したつもりてもコマンドを適当に組み合わせたら偶然できるようなレベル
web上に消し方の情報が沢山あるのはそういう理由
2022/02/28(月) 10:01:03.24ID:1ziskyp5
>>77
76は>>75への返信
2022/02/28(月) 13:10:38.48ID:5+6VAuli
試す気はないけど
>>64で再現できるんでね?
2022/02/28(月) 14:17:24.11ID:9W2zYqHy
そりゃあえて迂回したらな

Test-Path -IsValidは信頼できるのだろうか?
中身分からものに頼るよりendswith(". ")とかで自分でバリデーションするべきか
2022/02/28(月) 14:24:32.38ID:9W2zYqHy
任意文字列渡されてもそのまま作らせない、あるいは勝手に置換+ユニークIDにリネームが現実的な防御策か
ファイルシステム移行で問題起こす事もあるし、どこでも合法なファイル名に正規化しておいた方が後のため
2022/02/28(月) 15:01:04.99ID:Xoh24ILj
>>79
ID変わってるけど64と78は同一人物です
psを普通に使う範囲までこのOSの瑕疵を気のするのは過剰品質だと感じるし、日本の安心安全神話で生産性クソ低い件を連想してしまう
2022/02/28(月) 15:11:14.28ID:NrGkgOto
bashとか平気で不正ファイルポンポン作るからヤバい
OSが拒否するのを期待してるからそれ自体が悪い訳ではないのだが、安易にwindowsで使うのは本当にヤバい
2022/02/28(月) 15:27:14.93ID:9W2zYqHy
win版のgitに付いてくるの使ってるけど、unix系ツールはファイルシステムに気を使う移植は見たことがない
仮想ドライブに隔離してしまうのが手っ取り早くて安全そう
2022/02/28(月) 15:40:26.92ID:9W2zYqHy
>>82
これな
考えれば考えるだけボロが出てくるし思考放棄することにした

行儀悪いプログラムの後始末のやり方だけ知っときゃいいのよ
(真剣な仕事でなければ)
2022/02/28(月) 15:51:52.53ID:9W2zYqHy
win11ではこっそり治ってたりしねーかなこれ、なければwin12に乞うご期待…
2022/03/01(火) 03:09:34.84ID:L/ghTddK
>>82
これは瑕疵ではない、仕様とMSは一応言ってるんじゃね?

>>67によると ↓ だそうだから、自分でちゃんとチェックしろ、対処しろということだろうし

ファイル i/o の場合、 \ \ パス文字列の "? \ " プレフィックスは、すべての文字列解析を無効にし、その後に続く文字列をファイルシステムに送信するために、Windows api に指示します。

↑こう書くのはおそらく他OSのコードをそのまま移植しやすくするため、なんでね?

つまり何もチェック(今回の例なら末端にスペース入ってないか)せずにAPIに渡すと
結果として>>29のようなことが起き得ると
2022/03/01(火) 03:14:07.19ID:L/ghTddK
あ、>>29では>>64の書式では書いてないのか
>>64の動作は仕様だと思うけど>>29でなったのならバグだな(試す気はない)
2022/03/01(火) 13:31:53.46ID:fDW5QBJr
powershellで文字コード?順でソートしたい時どうしたらいいんでしょう
3---t.txt
3-1-t.txt
4---t.txt
4-1-t.txt
ってファイルがある時、'-'が0x2dで'1'が0x31だから、
3---t.txt
3-1-t.txt
4---t.txt
4-1-t.txt
と並ぶのを期待したのに昇順でソートしたら
gci | sort
3-1-t.txt
3---t.txt
4-1-t.txt
4---t.txt
になってしまう
今確認したらcmdのdir /ONオプションでも同じだった
2022/03/01(火) 13:42:53.50ID:fDW5QBJr
ファイル名の末尾の英字取って
3---.txt
3-1-.txt
4---.txt
4-1-.txt
としたら
3---.txt
3-1-.txt
4---.txt
4-1-.txt
になったけど意味が判らない
変なバグに遭遇した気分
2022/03/01(火) 16:20:44.39ID:XlErARwx
最近のWindowsは9.txtの後ろに10.txtが並ぶように数の大小を考慮したソートを標準で行うからそのアルゴリズムが生む微妙な綾じゃね
レジストリによって挙動が変わるはず
文字コード順を順守させたいならファイル名標準のソートにならないように、ハッシュテーブルの引数なんかを使って単なる文字列としてソートしてあげればいいんじゃないかな
2022/03/01(火) 22:49:13.37ID:qg4SVCg0
テストしてないし遅い気がするけど
下準備なしがよければ
gci | sort {[Text.Encoding]::Unicode.GetBytes($_.Name) | %{'{0,3}' -f $_}}

※Shift_JIS基準がよければ
gci | sort {[Text.Encoding]::GetEncoding('shift_jis').GetBytes($_.Name) | %{'{0,3}' -f $_}}

重複ないなら
$list = [Collections.Generic.SortedList[string,IO.FileSystemInfo]]::new([StrintygComparer]::Ordinal)
gci | %{$list.Add($_.Name, $_)}

重複あるなら
$list = [Collections.Generic.List[IO.FileSystemInfo]]::new()
$list.AddRange([IO.FileSystemInfo[]]@(gci))
$list.Sort({Param($a, $b) [StringComparer]::Ordinal.Compare($a.Name, $b.Name)})
2022/03/02(水) 17:07:09.87ID:HFEr6ITo
>>92
めっちゃ参考になった
ありがとう
2022/03/02(水) 17:54:20.18ID:qWIZmWPY
>>89
PowerShell 5.1だと確かにそうなるけど
PowerShell 7.2.1だとgci | sort で期待通りの結果になったよ
最新バージョン使った方が良いんでない?
2022/03/02(水) 21:57:02.42ID:Gj5Erajd
PowerShellでSQliteのデータベースに追記操作しようと思っていますが
テーブル名を変数にし、カラムと追記したい内容を配列で操作しようとすると上手くいきません。
一括で出来ないなら配列内ループでと思いやってみましたが、そちらもうまくいきませんでした。
配列でINSERTするには、以下のサンプルだとどういった記述をすればよいのでしょうか?
2022/03/02(水) 21:57:57.51ID:Gj5Erajd
using namespace System.Data.SQLite

Set-StrictMode -Version Latest
$ErrorActionPreference = "STOP"

# モジュールのインポート
Import-Module SQLite

# データベースファイル
$db_path = "E:\ps1\sqlite\sample.db"

# コネクションオブジェクトの生成
$con = [SQLiteConnection]::new() | % {
$_.ConnectionString = ("Data Source = {0}"-f $db_path)
$_.Open()
$_
}

$cmd = [SQLiteCommand]::new()
$cmd.Connection = $con
2022/03/02(水) 21:59:03.05ID:Gj5Erajd
$Table = "List"
$ArrCol = @("No","Name","Gender")
$ArrRecord = @("1","山田","男")
2022/03/02(水) 21:59:46.03ID:Gj5Erajd
# レコードの追加
$cmd.CommandText = @"
INSERT INTO $Table ($ArrCol) values ($ArrRecord)
"@
2022/03/03(木) 00:11:25.85ID:Ai6V8ofW
どこでどんなエラーが出てるのか分からないし試してないけど
文字列の中で配列変数をそのまま展開してるのが原因なんじゃないかな。

$cmd.CommandText = @"
INSERT INTO $Table ($($ArrCol -join ', ')) values ($($ArrRecord -replace '^|$', "'" -join ', '))
"@

※余計なお世話だろうけどインジェクション対策がないので必要なら入れてね。
 (SQLiteがサポートしてるか知らないけど通常はSQLパラメータを使用。)
2022/03/03(木) 07:55:37.70ID:vKIVQ1+Z
>>99
ありがとうございます。
一回やってみます
2022/03/03(木) 22:26:57.79ID:vKIVQ1+Z
すみません、色々試したのですがわからずまた質問させてください

$Table = "2022"
$ArrCol = @("No","Day","Name")
$ArrRecord = @("1","2022/03/03","山田")

だとして
2022/03/03(木) 22:35:42.15ID:vKIVQ1+Z
cmd.CommandText = @"
INSERT INTO "2020" ("No","Day","Name") values ("1","2022/03/03","山田")
"@
だとエラーなくデータベースに追記出来るのですが
2022/03/03(木) 22:37:17.23ID:vKIVQ1+Z
$cmd.CommandText = @"
INSERT INTO [string]$Table ("No","Day","Name") values ("1","2022/03/03","山田")
"@

だと"0"個の引数を指定して"ExecuteNonQuery"を呼び出し中に例外が発生しました"SQLite error near "2022":syntax error"
2022/03/03(木) 22:37:58.49ID:vKIVQ1+Z
あと
$cmd.CommandText = @"
INSERT INTO "2022" ($($ArrCol -join ', ')) values ("1","2022/03/03","山田")
"@


$cmd.CommandText = @"
INSERT INTO "2022" ("No","Day","Name") values ($($ArrRecord -replace '^|$', "'" -join ', '))
"@

だと
"0"個の引数を指定して"ExecuteNonQuery"を呼び出し中に例外が発生しました"SQLite error near "/":syntax error"

とエラーが出てデータベースを変更できませんでした
色々試したのですが理由がわからず申し訳ございませんが教えたもらいたく
2022/03/03(木) 22:42:34.74ID:vKIVQ1+Z
すみません
5chだとSQL関係で書き込めなかったのですが

$cmd.え(E)xecuteNonQuery() | Out-Null
も各場所で記入しています
2022/03/04(金) 01:01:51.54ID:rY0dcLRW
SQLをデータベースに渡す前に、ヒアドキュメントがどう変数展開されているのかデバッグしたりコンソール出力してみるといいよ
いろいろミスに気づくはず
軽く見た感じ次のように展開されてる気がする
INSERT INTO [string]2022 ("No","Day","Name") values ("1","2022/03/03","山田")
INSERT INTO "2022" (No, Day, Name) values ("1","2022/03/03","山田")
INSERT INTO "2022" ("No","Day","Name") values (1, 2022/03/03, 山田)
2022/03/05(土) 08:12:15.74ID:UxduI4YM
PowerShell and OpenSSH team investments for 2022
https://devblogs.microsoft.com/powershell/powershell-and-openssh-team-investments-for-2022/

We continue to explore and discuss with the Windows team how to make it easier to deploy PowerShell 7 on Windows.
As noted previously, support lifecycle differences between Windows and .NET along with size constraints we don’t have the ability currently to ship PowerShell 7 in Windows.
Previously we considered a bootstrapper to be a viable solution giving the experience of being inbox in Windows, however, it would have been a significant effort to implement.
Instead, we are exploring shipping a cmdlet in Windows PowerShell to make it easy to install PowerShell 7.
A new RFC will be published to discuss this.
10892
垢版 |
2022/03/05(土) 11:18:59.79ID:2eHlJFPP
>>92
1つ目の例のUnicodeはUTF-16LEの事だからだめだったね。
BigEndianUnicode(UTF-16BE)にする必要があったし、
そもそもbyte型にしてエンディアン気にする必要もないから、
gci | sort {[int[]][char[]]$_.Name | %{'{0,5}' -f $_}}
でよいはず。
※全く関係ない別の作業中になんか急に気づいた。
10999
垢版 |
2022/03/05(土) 11:34:56.78ID:2eHlJFPP
SQLiteがカラム名等を「"」で括る事を要求しているなら
$cmd.CommandText = @"
INSERT INTO "$Table" ($($ArrCol -replace '^|$', '"' -join ', ')) values ($($ArrRecord -replace '^|$', '"' -join ', '))
"@
かな。>>106さんの言う通りなので確認してみて。

これもだめなら、成功例と、失敗例や変数値のテーブル名が違うからそこかも。
2022/03/05(土) 17:03:38.16ID:aFkos6IC
>>107
もう開発やめりゃいいのにな
これまでWindowsに入ってるから採用されてきただけで、わざわざ入れて使うならPowerShellなんか選ばれるわけがない
コマンドレットで簡単に導入できるようにするならPowerShellじゃなくてPythonにでもしたほうがいいんじゃないか
2022/03/05(土) 22:04:13.92ID:BfpuuE1g
インストールしてなくてもpythonコマンドでMSストア版pythonのダウンロードページに飛ばされるから、既にpwsh7よりも導入が楽という悲しみ
2022/03/05(土) 22:12:35.50ID:vfk/Azs+
PowerShellってそんな残念なプログラム言語なんですか?
がんばって勉強したのに納得できません
2022/03/05(土) 22:41:29.84ID:ws14fGQi
PowerShell5系は向こう10年は大丈夫
6以降はAzure以外では全く使われておらず、Azureに生涯を捧げるのでない限りは完全無視でOK
2022/03/06(日) 11:25:06.52ID:2dMAfvhM
メインは蛇使いだけど
色々インポートしなくてもそこそこ戦えるのでregex、小規模データ処理、重くない数値計算がシェルから直接引けるpwshは有り難い

ネイティブライブラリ揃ってないからパワーが居るのはPython、まあPython自体はpwshとドングリ背比べ(処理速度、標準ライブラリもほぼ等価)だけど、やはりライブラリが強い
2022/03/06(日) 11:37:06.16ID:Ou5vEvLf
蛇使いwww
蠍と射手の間かよwww
2022/03/06(日) 14:35:41.73ID:2wKnUbYj
Pythonは.NETを使えないから糞
2022/03/06(日) 15:35:16.76ID:+PaQnGDE
PowershellとPythonだと得意分野が違うよね
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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