素人丸出しお粗末で遅くてもいいので
いますぐ使えるちょっぴり便利プログラムを作れ
(例○○を自動処理してくれるプログラム)
VBSで便利なプログラムを作れスレ
■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん
2007/02/03(土) 17:49:47427デフォルトの名無しさん
2011/06/19(日) 08:19:38.57 GetObject
428デフォルトの名無しさん
2011/06/19(日) 08:29:07.02 USB股間に忍ばせて持ち歩く男の人って・・・///
きみの端子にプラグ★イン!
きみの端子にプラグ★イン!
429≠423
2011/06/19(日) 10:02:11.33430デフォルトの名無しさん
2011/06/19(日) 12:12:42.62 なんか勘違いしてる子が出てきたなw
あのね、comにインストールの壁なんて無いって話であって
USBメモリなんて、全く関係ない話なのよ
それと、『ある程度』レベルの会社だと、勝手にツール類をインストールする事ができないところが多いけど
『ある程度』を超えたまともな会社だと、勝手にツール類をインストールする事が出来るところも多い
セキュリティーが確立している上に、VBAやWSHなどの元から入ってる言語でいろいろ作れる奴が多いから
外部からのツールのインストールを制限しても、元から入ってる言語でツールが作れちゃうから意味無いw
逆にまともな会社だでツールのインストールを制限している場合は、WSHもVBAも制限してる
あのね、comにインストールの壁なんて無いって話であって
USBメモリなんて、全く関係ない話なのよ
それと、『ある程度』レベルの会社だと、勝手にツール類をインストールする事ができないところが多いけど
『ある程度』を超えたまともな会社だと、勝手にツール類をインストールする事が出来るところも多い
セキュリティーが確立している上に、VBAやWSHなどの元から入ってる言語でいろいろ作れる奴が多いから
外部からのツールのインストールを制限しても、元から入ってる言語でツールが作れちゃうから意味無いw
逆にまともな会社だでツールのインストールを制限している場合は、WSHもVBAも制限してる
431デフォルトの名無しさん
2011/06/19(日) 18:14:48.56 ≠423とか必死に否定すると、余計に・・・・・( ̄ー ̄)ニヤリッ
432デフォルトの名無しさん
2011/06/19(日) 21:27:41.80 「勝手に出来る」って方がおかしいだろ
今の時代どこもピリピリしてるってのに。
単におまえさん自身か会社がその客に信用されてるってだけじゃねーの?
でも普通は申請式だと思うけど。他人の会社で勝手にてのはどうかと思う。
今の時代どこもピリピリしてるってのに。
単におまえさん自身か会社がその客に信用されてるってだけじゃねーの?
でも普通は申請式だと思うけど。他人の会社で勝手にてのはどうかと思う。
433デフォルトの名無しさん
2011/06/20(月) 00:02:07.13 勝手にしてよいと許されていることを勝手にやる上で、何の咎があると?
なにか勘違いしてやいないか?
なにか勘違いしてやいないか?
434デフォルトの名無しさん
2011/06/20(月) 00:33:54.55 これは突っ込んであげたほうが良いのだろうか?
435デフォルトの名無しさん
2011/06/20(月) 00:59:30.37 生温かい目で見守ってあげるのが良いんじゃないかと
436デフォルトの名無しさん
2011/06/20(月) 10:20:41.11 batファイルは止められませんね
じゃぁバッチ最強じゃん
じゃぁバッチ最強じゃん
437デフォルトの名無しさん
2011/06/20(月) 17:46:53.34 <a href="http://upload.jpn.ph/500/bin/やきそば.zip">こちら</a>
という内容のテキストファイルからURLの部分を抽出して
変数に入れるっていう目的でvbs作ったんですが上手く変数に入りません
Dim objFile ' 対象ファイル
Dim oldText ' 置換前テキスト
Dim newText ' 置換後テキスト
Dim objFSO ' ファイルシステムオブジェクト
Dim objRep ' 正規表現オブジェクト
Dim repText ' 置換対象文字列
var1 = "解析.txt" '保存する名前
Set objFSO = CreateObject("Scripting.FileSystemObject")
Set objFile = objFSO.OpenTextFile(var1, 1, false, 0)
' テキストデータ読込
oldText = objFile.ReadAll
patrn="(http:\/\/[^\x22 ]+)" '検索する文字列を入力して下さい。
repText = "$2"
Set objRep = New RegExp
objRep.Multiline = True
' 正規表現パターンを指定する
objRep.Pattern = patrn
oldText = objRep.replace(oldText, repText)
WScript.Echo $2
objFile.Close
どうすればいいのでしょうか、もしわかるかた入れば教えてください。
自分では後方参照とかExecuteやマッチとかが関係ありそうで
調べて試したんですが思うようにいきませんでした。
という内容のテキストファイルからURLの部分を抽出して
変数に入れるっていう目的でvbs作ったんですが上手く変数に入りません
Dim objFile ' 対象ファイル
Dim oldText ' 置換前テキスト
Dim newText ' 置換後テキスト
Dim objFSO ' ファイルシステムオブジェクト
Dim objRep ' 正規表現オブジェクト
Dim repText ' 置換対象文字列
var1 = "解析.txt" '保存する名前
Set objFSO = CreateObject("Scripting.FileSystemObject")
Set objFile = objFSO.OpenTextFile(var1, 1, false, 0)
' テキストデータ読込
oldText = objFile.ReadAll
patrn="(http:\/\/[^\x22 ]+)" '検索する文字列を入力して下さい。
repText = "$2"
Set objRep = New RegExp
objRep.Multiline = True
' 正規表現パターンを指定する
objRep.Pattern = patrn
oldText = objRep.replace(oldText, repText)
WScript.Echo $2
objFile.Close
どうすればいいのでしょうか、もしわかるかた入れば教えてください。
自分では後方参照とかExecuteやマッチとかが関係ありそうで
調べて試したんですが思うようにいきませんでした。
438デフォルトの名無しさん
2011/06/21(火) 21:55:45.73 まずは基本を学べってレベル
439デフォルトの名無しさん
2011/06/23(木) 15:44:28.14 正規表現の構文がデタラメ。
パターンがデタラメだし後方参照の仕方もデタラメ。
ヘルプもろくに見てないだろ。
パターンがデタラメだし後方参照の仕方もデタラメ。
ヘルプもろくに見てないだろ。
440デフォルトの名無しさん
2011/06/23(木) 22:13:57.11441デフォルトの名無しさん
2011/06/23(木) 22:32:18.65 凄い違和感あったんだけど納得
442デフォルトの名無しさん
2011/06/23(木) 23:57:00.51443デフォルトの名無しさん
2011/06/24(金) 07:22:39.31 久しぶりに酷い自演をみた
444デフォルトの名無しさん
2011/06/24(金) 10:19:04.37 >repText = "$2"
この意味不明っぷりがすごいね
この意味不明っぷりがすごいね
445デフォルトの名無しさん
2011/06/24(金) 14:11:47.65 突っ込む所はそこじゃないと思うがw
Echoのとことか、パターン自体に突っ込めよ
Echoのとことか、パターン自体に突っ込めよ
446デフォルトの名無しさん
2011/06/24(金) 14:15:34.45447デフォルトの名無しさん
2011/06/24(金) 19:23:21.29448デフォルトの名無しさん
2011/06/25(土) 00:10:36.15 >>437も恥ずかしくて出れこれないんだから、いい加減に許してやれよ
449デフォルトの名無しさん
2011/06/25(土) 13:11:24.67 >>443
そんなに悔しかったの?
そんなに悔しかったの?
450天使 ◆KOAgYBL/Xg
2011/06/29(水) 17:41:46.87 さすが VBSなんていう時代遅れツール使ってるスレはレベルが低い
451天使 ◆uL5esZLBSE
2011/07/02(土) 08:25:05.28ゴミみたいな奴だな
452デフォルトの名無しさん
2011/08/28(日) 14:30:43.29 文字を文字コードの数値に変換して出力したいんだけど誰か助けて
453デフォルトの名無しさん
2011/08/28(日) 20:10:45.21 asc("a")
454デフォルトの名無しさん
2011/09/01(木) 09:14:32.07 何その顔文字、ふざけてるの
455デフォルトの名無しさん
2011/09/01(木) 10:09:24.83 ("з")
456デフォルトの名無しさん
2011/11/20(日) 14:29:12.95 (・∀・)
457デフォルトの名無しさん
2011/11/20(日) 15:33:06.16 VBScriptって、1ヶ月もあれば極められるよね
あとはCOMを何処まで使いこなせるかだけ
あとはCOMを何処まで使いこなせるかだけ
458デフォルトの名無しさん
2011/11/21(月) 17:49:41.03 そんな時期もありました
459デフォルトの名無しさん
2012/02/10(金) 21:02:00.29 例えば、notepad.exeを起動するvbsは?
460デフォルトの名無しさん
2012/02/10(金) 21:08:54.09461459
2012/02/10(金) 22:23:36.81 >460
分かりました。ありがとう
ところで、Option Explicitを書くとshellが宣言されてないと起こられますが
この場合、shellの型は何ですか?
あるいは、Option Explicitを書くべきじゃない?
分かりました。ありがとう
ところで、Option Explicitを書くとshellが宣言されてないと起こられますが
この場合、shellの型は何ですか?
あるいは、Option Explicitを書くべきじゃない?
462デフォルトの名無しさん
2012/02/10(金) 22:46:07.22 >>461
Object 型
VBScript では VB や VBA と違い、宣言で型を記述しないのであまり意識はしないが、
Object 型だけは代入時に Set を必要とするので認識は必要
あと、Option Explicit は書いた方がよい
Option Explicit
Dim shell
Set shell = CreateObject("WScript.Shell")
shell.Run "notepad"
Object 型
VBScript では VB や VBA と違い、宣言で型を記述しないのであまり意識はしないが、
Object 型だけは代入時に Set を必要とするので認識は必要
あと、Option Explicit は書いた方がよい
Option Explicit
Dim shell
Set shell = CreateObject("WScript.Shell")
shell.Run "notepad"
463459
2012/02/11(土) 07:35:54.95 >462
ありがとうございました
ありがとうございました
464デフォルトの名無しさん
2012/02/12(日) 01:57:20.27 Option Explicitはtypo無くしてくれるからな
昔のソース改修でstrPrinterとstrPrnterで1週間ぐらいハマった記憶
今なら真っ先に疑うけど当時はまだ慣れてなくて泣いたなぁ
昔のソース改修でstrPrinterとstrPrnterで1週間ぐらいハマった記憶
今なら真っ先に疑うけど当時はまだ慣れてなくて泣いたなぁ
465デフォルトの名無しさん
2012/03/10(土) 23:34:01.81 >>462
CreateObject()の戻り値がObject型ってだけで変数に型は無いよ
Object型を変数に代入するのに、Setが必要なだけ
その証拠に、
Set shell = CreateObject("WScript.Shell")
shell = 1 '変数に型は無いので、この代入は有効
shell.Run "notepad" '変数には数値型のデータが入っているので、ここでエラーが発生
細かい事だけど、知っているのと知らないのでは大違い
>>464
typoを無くす為にOption Explicitを宣言してはいけない
Option Explicitの宣言は、ローカル変数とグローバル変数の区別を明確にするために宣言すべき
CreateObject()の戻り値がObject型ってだけで変数に型は無いよ
Object型を変数に代入するのに、Setが必要なだけ
その証拠に、
Set shell = CreateObject("WScript.Shell")
shell = 1 '変数に型は無いので、この代入は有効
shell.Run "notepad" '変数には数値型のデータが入っているので、ここでエラーが発生
細かい事だけど、知っているのと知らないのでは大違い
>>464
typoを無くす為にOption Explicitを宣言してはいけない
Option Explicitの宣言は、ローカル変数とグローバル変数の区別を明確にするために宣言すべき
466デフォルトの名無しさん
2012/03/11(日) 04:51:38.09 > 変数に型は無いよ
ちょっとハズレ
正しくはVBSの変数の型は、無いのではなくValiant型のみというだけ
で、Valiant型は内部型が固定されていないのでどんな型の値をも代入することが可能だが
値が代入されている状態では、内部に歴とした型という概念が存在する
細かい事だけど、内部文字列型と内部数値型では、外がValiant型でも扱いが異なるので、
知っているのと知らないのでは大違い
> Option Explicitの宣言は、ローカル変数とグローバル変数の区別を明確にするために宣言すべき
それ、VBやVBAの場合ね
それらの場合はグローバル変数(全モジュール共通変数)とモジュール内変数の区別に役立つ
でもVBSの変数スコープには、グローバル変数、プロシージャ内変数、クラス内変数の3つがあるが
Option Explicitはこれらの区別を明確にする役目は果たさない
ちょっとハズレ
正しくはVBSの変数の型は、無いのではなくValiant型のみというだけ
で、Valiant型は内部型が固定されていないのでどんな型の値をも代入することが可能だが
値が代入されている状態では、内部に歴とした型という概念が存在する
細かい事だけど、内部文字列型と内部数値型では、外がValiant型でも扱いが異なるので、
知っているのと知らないのでは大違い
> Option Explicitの宣言は、ローカル変数とグローバル変数の区別を明確にするために宣言すべき
それ、VBやVBAの場合ね
それらの場合はグローバル変数(全モジュール共通変数)とモジュール内変数の区別に役立つ
でもVBSの変数スコープには、グローバル変数、プロシージャ内変数、クラス内変数の3つがあるが
Option Explicitはこれらの区別を明確にする役目は果たさない
467デフォルトの名無しさん
2012/03/11(日) 09:35:32.83 >>466
だから、違うって
全ての変数は型が無いことを保障されてるの、これをValiant型と言います
そして、型を持っているのは、データ側であって変数ではありません
変数に型がある場合は、オブジェクト型の変数に整数を代入する事は絶対に出来ません
次に、Option Explicitは、全てのスコープにDim文を強制します
VBScriptの仕様では、Dimで宣言された変数は該当スコープでのローカル変数として確実に扱われるが、Dimで宣言されない変数は、同名のグローバル変数がある場合、グローバル変数として扱われます
ようは、使うべきでないグローバル変数を誤って使う事をしない為に使われるのであって、typo問題の為に使われているのではない
考えるまでもなく、typoによって引き起こされる問題よりも、グローバル変数への不用意なアクセスによる影響の方がはるかに大きく深刻です
だから、違うって
全ての変数は型が無いことを保障されてるの、これをValiant型と言います
そして、型を持っているのは、データ側であって変数ではありません
変数に型がある場合は、オブジェクト型の変数に整数を代入する事は絶対に出来ません
次に、Option Explicitは、全てのスコープにDim文を強制します
VBScriptの仕様では、Dimで宣言された変数は該当スコープでのローカル変数として確実に扱われるが、Dimで宣言されない変数は、同名のグローバル変数がある場合、グローバル変数として扱われます
ようは、使うべきでないグローバル変数を誤って使う事をしない為に使われるのであって、typo問題の為に使われているのではない
考えるまでもなく、typoによって引き起こされる問題よりも、グローバル変数への不用意なアクセスによる影響の方がはるかに大きく深刻です
468デフォルトの名無しさん
2012/03/11(日) 10:11:16.22 バリアントの綴りが間違ってた...
ValiantではなくVariantでした。
ValiantではなくVariantでした。
469デフォルトの名無しさん
2012/03/11(日) 10:54:20.03 なんだ、この子全然解ってないんだね
470デフォルトの名無しさん
2012/03/11(日) 11:14:12.71471デフォルトの名無しさん
2012/03/11(日) 13:25:47.06 痛すぎw
472デフォルトの名無しさん
2012/03/11(日) 13:38:11.81473デフォルトの名無しさん
2012/03/11(日) 18:41:00.25 >>467
横レスだけど
ローカルとグローバルでの変数名は、設計レベルで対応すべき話では?
実際の製造(プログラミング)時はtypo対策の方が重要では
そもそも、グローバルとプロシージャレベルで同名変数使うって
どれだけ可読性の低いプログラムを書くつもりかと。
普通コーディングルールで禁止されていると思うし、自分なら禁止する
個人レベルならともかく企業でもVB系言語を使う以上、Option Explicitは
BASICを、普通の(変数宣言を強制する)プログラミング言語と
同レベルに引き上げるものだと思ってるけど
とMSX-BASIC1から入って業務でVBは2(Win版。流石にDOS版は触って無い)から
使っている年寄りとしては思う
横レスだけど
ローカルとグローバルでの変数名は、設計レベルで対応すべき話では?
実際の製造(プログラミング)時はtypo対策の方が重要では
そもそも、グローバルとプロシージャレベルで同名変数使うって
どれだけ可読性の低いプログラムを書くつもりかと。
普通コーディングルールで禁止されていると思うし、自分なら禁止する
個人レベルならともかく企業でもVB系言語を使う以上、Option Explicitは
BASICを、普通の(変数宣言を強制する)プログラミング言語と
同レベルに引き上げるものだと思ってるけど
とMSX-BASIC1から入って業務でVBは2(Win版。流石にDOS版は触って無い)から
使っている年寄りとしては思う
474デフォルトの名無しさん
2012/03/11(日) 18:57:57.83 QB「
475デフォルトの名無しさん
2012/03/11(日) 19:15:38.79476デフォルトの名無しさん
2012/03/11(日) 20:27:28.25 Dimで解決するだろ
477デフォルトの名無しさん
2012/03/11(日) 21:49:45.91 >>476
だからソースの始めに、Option Explicitが必要なんじゃんw
だからソースの始めに、Option Explicitが必要なんじゃんw
478デフォルトの名無しさん
2012/03/11(日) 22:27:49.57479デフォルトの名無しさん
2012/03/11(日) 23:22:53.96 >>478
お前、馬鹿だろw
Option Explicitが書いてあれば、ローカルでDim宣言されている証明になるが
Option Explicitが書いてあっても、typoしていない証明にはならない
お前、馬鹿だろw
Option Explicitが書いてあれば、ローカルでDim宣言されている証明になるが
Option Explicitが書いてあっても、typoしていない証明にはならない
480デフォルトの名無しさん
2012/03/12(月) 06:39:57.23 なんか、自分自身が勘違いしていて痛い奴だってことに気付いてない
蘊蓄野郎が一人でずっと頑張ってるなぁ
蘊蓄野郎が一人でずっと頑張ってるなぁ
481デフォルトの名無しさん
2012/03/12(月) 09:02:44.77 Option Explicitでtypo対策する奴の方がよっぽど痛いけどね
482デフォルトの名無しさん
2012/03/12(月) 19:53:12.43 普通に考えて、変数名をコピペしてたらtypoなんて起きないだろ...
つーかtypoが問題になるって何十年前の開発環境だよ...
つーかtypoが問題になるって何十年前の開発環境だよ...
483デフォルトの名無しさん
2012/03/12(月) 20:26:55.78 入力補完じゃなくてコピペって・・・・・
それこそ何十年前だよって話だなw
程度が知れてきたぜ
それこそ何十年前だよって話だなw
程度が知れてきたぜ
484デフォルトの名無しさん
2012/03/12(月) 20:44:07.58 うはっ、入力補完機能のあるエディタ使ってて、変数名のtypoがプログラム制作上の重要課題ってw
あれだな、うちのメモ帳の方が、あんたの開発環境よりも上って事だなw
この10数年の間、変数名のtypoなんて起きた事ねぇもんw
あれだな、うちのメモ帳の方が、あんたの開発環境よりも上って事だなw
この10数年の間、変数名のtypoなんて起きた事ねぇもんw
485デフォルトの名無しさん
2012/03/12(月) 20:56:31.62 この子、相手が一人だと思ってるのかな?
俺は変数名のtypoがプログラム制作上の重要課題なんて一言も言ってないんだが
必死になりすぎて周りの現実が見えてないんだね
大勢に嘲笑されているという現実が・・・・・
俺は変数名のtypoがプログラム制作上の重要課題なんて一言も言ってないんだが
必死になりすぎて周りの現実が見えてないんだね
大勢に嘲笑されているという現実が・・・・・
486デフォルトの名無しさん
2012/03/12(月) 21:10:17.75 うはっw
とうとう、「俺はtypoなんて言ってねぇ」とか言い出しちゃいましたよ
このお方w
とうとう、「俺はtypoなんて言ってねぇ」とか言い出しちゃいましたよ
このお方w
487デフォルトの名無しさん
2012/03/12(月) 21:13:40.15 入れ食い
488デフォルトの名無しさん
2012/03/12(月) 21:20:02.41 そもそもプロシージャとグローバルで名前重複なんて、可読性が低くて
絶対保守したくない類のソース。機械が読めても人が読みにくい。
Option Explicit以前にその時点で根本的に間違っていると思う。
それ以前に最近は「グローバル変数自体原則禁止、明示的に引数で渡すべき」
とか言われる事も多くて、高度情報処理試験の午前問題にもあったり。
ま、あくまで「原則」なんでグローバル変数を使わざるを得ない場合もあるが
独立性が低下するので再利用性が低下するのは避けられない。
つまりはスコープの違いをOption Explicitでどうこうして再利用性を上げようとする
のは方針自体が間違っている。
引数のオーバーヘッドに関しても昔はともかく今はPCの性能が十分高いので
高速策よりも安全策というか保守性を取る方が多いし。
VBSの場合は短い事もあり汎用的に使うfsoとかはグローバルな事も多いけど。
絶対保守したくない類のソース。機械が読めても人が読みにくい。
Option Explicit以前にその時点で根本的に間違っていると思う。
それ以前に最近は「グローバル変数自体原則禁止、明示的に引数で渡すべき」
とか言われる事も多くて、高度情報処理試験の午前問題にもあったり。
ま、あくまで「原則」なんでグローバル変数を使わざるを得ない場合もあるが
独立性が低下するので再利用性が低下するのは避けられない。
つまりはスコープの違いをOption Explicitでどうこうして再利用性を上げようとする
のは方針自体が間違っている。
引数のオーバーヘッドに関しても昔はともかく今はPCの性能が十分高いので
高速策よりも安全策というか保守性を取る方が多いし。
VBSの場合は短い事もあり汎用的に使うfsoとかはグローバルな事も多いけど。
489デフォルトの名無しさん
2012/03/12(月) 22:18:26.28 >>488
馬鹿か
なんの為のスコープ分けだ
もう一度、構造化プログラムについて習いなおせ
互いのスコープが引数と戻り値のみでのみデータの受け渡しをする限り、互いの内部の処理は気にする必要は無いの
そして、VBScriptの場合は、グローバルスコープへ直接コーディングをする可能性があるから、Option Explicitによるコードの再利用性の保障が必要なんだっつうの
馬鹿か
なんの為のスコープ分けだ
もう一度、構造化プログラムについて習いなおせ
互いのスコープが引数と戻り値のみでのみデータの受け渡しをする限り、互いの内部の処理は気にする必要は無いの
そして、VBScriptの場合は、グローバルスコープへ直接コーディングをする可能性があるから、Option Explicitによるコードの再利用性の保障が必要なんだっつうの
490デフォルトの名無しさん
2012/03/12(月) 22:31:33.94 Option Explicit「みんな!私のために争わないで!」
491デフォルトの名無しさん
2012/03/13(火) 06:14:50.44 >>489
らちが明かないから何かサンプル上げて説明してみて
らちが明かないから何かサンプル上げて説明してみて
492デフォルトの名無しさん
2012/03/13(火) 09:37:52.97 >>491
まず共通部分
<job id="main">
<script language="VBScript" src="test.vbs" />
<script language="VBScript">
fso = "Hello"
MsgBox Test() & vbCrlf & fso
</script>
</job>
まず共通部分
<job id="main">
<script language="VBScript" src="test.vbs" />
<script language="VBScript">
fso = "Hello"
MsgBox Test() & vbCrlf & fso
</script>
</job>
493デフォルトの名無しさん
2012/03/13(火) 09:39:40.86 次に、test.vbs部分Option Explicit無しバージョン
Function Test()
Set fso = CreateObject("Scripting.FileSystemObject")
Set File = fso.OpenTextFile("test.vbs")
Test = File.ReadAll
Set fso = Nothing
End Function
Function Test()
Set fso = CreateObject("Scripting.FileSystemObject")
Set File = fso.OpenTextFile("test.vbs")
Test = File.ReadAll
Set fso = Nothing
End Function
494デフォルトの名無しさん
2012/03/13(火) 09:43:32.86 こいつも、test.vbsでOption Explicit有りバージョン
Option Explicit
Function Test()
Dim fso, File
Set fso = CreateObject("Scripting.FileSystemObject")
Set File = fso.OpenTextFile("test.vbs")
Test = File.ReadAll
Set fso = Nothing
End Function
Option Explicit
Function Test()
Dim fso, File
Set fso = CreateObject("Scripting.FileSystemObject")
Set File = fso.OpenTextFile("test.vbs")
Test = File.ReadAll
Set fso = Nothing
End Function
495デフォルトの名無しさん
2012/03/13(火) 21:41:15.30 散々蘊蓄垂れてこのレベルか
496デフォルトの名無しさん
2012/03/13(火) 21:50:38.27 Option Explicit 云々以前の問題だな
497デフォルトの名無しさん
2012/03/13(火) 21:51:41.48 なんと見苦しい負け惜しみw
498デフォルトの名無しさん
2012/03/13(火) 22:25:08.04 >>493
>Option Explicit無しバージョン
Option ExplicitよりもローカルのDimが無い事の方が影響大でしょ
> ローカルDim無しバージョン
とした方がよいのでは?
別にOption Explicitによりローカル宣言とグローバル宣言の優先度が
変わったとかじゃないし
「Option Explicit」の有無「だけ」による挙動の違いを説明できないと
>Option Explicit無しバージョン
Option ExplicitよりもローカルのDimが無い事の方が影響大でしょ
> ローカルDim無しバージョン
とした方がよいのでは?
別にOption Explicitによりローカル宣言とグローバル宣言の優先度が
変わったとかじゃないし
「Option Explicit」の有無「だけ」による挙動の違いを説明できないと
499デフォルトの名無しさん
2012/03/13(火) 22:29:53.10 Option Explicit
Function Test()
Dim File
Set fso = CreateObject("Scripting.FileSystemObject")
Set File = fso.OpenTextFile("test.vbs")
Test = File.ReadAll
Set fso = Nothing
End Function
そんだけ言うなら、このパターンでも試してみたらw
Function Test()
Dim File
Set fso = CreateObject("Scripting.FileSystemObject")
Set File = fso.OpenTextFile("test.vbs")
Test = File.ReadAll
Set fso = Nothing
End Function
そんだけ言うなら、このパターンでも試してみたらw
500デフォルトの名無しさん
2012/03/14(水) 19:42:16.87 やれやれ、「Option Explicit」の使い方をようやく理解したか?
まあ、なんで、そのエラーが出るのか理解出来て無いってほうが濃厚だなw
なんせ、VBScriptの変数に内部型があるとか言っちゃうぐらいだからなぁw
まあ、なんで、そのエラーが出るのか理解出来て無いってほうが濃厚だなw
なんせ、VBScriptの変数に内部型があるとか言っちゃうぐらいだからなぁw
501デフォルトの名無しさん
2012/03/14(水) 19:45:33.07 自身が勘違いしていた事には気付いたが、
最初に強気で蘊蓄かましてしまった手前、
引くに引けなくなって強がりを続ける465萌え
最初に強気で蘊蓄かましてしまった手前、
引くに引けなくなって強がりを続ける465萌え
502デフォルトの名無しさん
2012/03/14(水) 20:28:49.55503デフォルトの名無しさん
2012/03/14(水) 20:47:40.14 ところで、既に>>499を提示してからでも丸一日が過ぎようとしているのに、今更、ファイルをクローズしてないとか言わないよねw
504デフォルトの名無しさん
2012/03/14(水) 21:55:18.55505デフォルトの名無しさん
2012/03/14(水) 23:04:31.90 もうそろそろ飽きてきた...
MSDNからのコピペ
−−−
Option Explicit ステートメント
スクリプト内のすべての変数に対して、明示的な宣言を強制します。
解説
Option Explicit ステートメントを使用する場合は、スクリプト内の他のステートメントより前に記述する必要があります。
Option Explicit ステートメントを記述した場合、変数は、Dim、Private、Public、ReDim などの各ステートメントで明示的に宣言する必要があります。宣言されていない変数名を使うと、エラーが発生します。
−−−
以上
ソースコードに、Option Explicitが記述されていると、変数の宣言は明示的に行わなければならない
つまり、>>493は、>>494に変更しなければエラーが出て実行できない
では、>>499で、変数fsoは明示的に宣言されていないのになぜOption Explicitはエラーを出さないのか
それは、グローバル変数としてOption Explicitの効果範囲外で暗黙的に宣言されているから
つまり、ローカル変数とグローバル変数が交じり合い、スコープが明確ではなくなって全ての変数が宣言済みなのでOption Explicitはエラーを出せなかった
この結果の意味するところは、Option Explicitは、スコープがあやふやな場合には、typoを検出する事は出来ない(>>499)
逆に、Option Explicitを宣言した状態で、スコープを明確にしデバッグすれば、プロシージャの独立性を保障する事ができる(>>494)
あれだ、>>498は目の付け所は良かったが、リファレンスぐらいは読んだほうが良いってこった
MSDNからのコピペ
−−−
Option Explicit ステートメント
スクリプト内のすべての変数に対して、明示的な宣言を強制します。
解説
Option Explicit ステートメントを使用する場合は、スクリプト内の他のステートメントより前に記述する必要があります。
Option Explicit ステートメントを記述した場合、変数は、Dim、Private、Public、ReDim などの各ステートメントで明示的に宣言する必要があります。宣言されていない変数名を使うと、エラーが発生します。
−−−
以上
ソースコードに、Option Explicitが記述されていると、変数の宣言は明示的に行わなければならない
つまり、>>493は、>>494に変更しなければエラーが出て実行できない
では、>>499で、変数fsoは明示的に宣言されていないのになぜOption Explicitはエラーを出さないのか
それは、グローバル変数としてOption Explicitの効果範囲外で暗黙的に宣言されているから
つまり、ローカル変数とグローバル変数が交じり合い、スコープが明確ではなくなって全ての変数が宣言済みなのでOption Explicitはエラーを出せなかった
この結果の意味するところは、Option Explicitは、スコープがあやふやな場合には、typoを検出する事は出来ない(>>499)
逆に、Option Explicitを宣言した状態で、スコープを明確にしデバッグすれば、プロシージャの独立性を保障する事ができる(>>494)
あれだ、>>498は目の付け所は良かったが、リファレンスぐらいは読んだほうが良いってこった
506デフォルトの名無しさん
2012/03/15(木) 04:54:39.64 負け犬の連投・・・
507デフォルトの名無しさん
2012/03/15(木) 08:42:06.70508デフォルトの名無しさん
2012/03/17(土) 10:04:12.29509デフォルトの名無しさん
2012/03/17(土) 14:33:29.53 こんなとこまで来ちゃうお前らの為じゃねーよ
適当にやったけど動いたからいーや的思考な
困ったくんや困ったチャンの為に書いてんだよOption Explicit
詳しい人が必ずメンテするとは限らないのがVB系の怖いとこで
適当にやったけど動いたからいーや的思考な
困ったくんや困ったチャンの為に書いてんだよOption Explicit
詳しい人が必ずメンテするとは限らないのがVB系の怖いとこで
2012/04/07(土) 09:29:55.75
こんなところに来ない人のための事をここに書いて意味あるんですか?
511デフォルトの名無しさん
2012/06/10(日) 17:05:31.39512デフォルトの名無しさん
2012/07/16(月) 00:40:56.77 今までUWSC(フリーソフト)を使っていましたが、最近、VBScriptを知り、同じような処理ができることを知りました。
VBScriptを勉強中です。
分からないことがあればよろしくね。
VBScriptを勉強中です。
分からないことがあればよろしくね。
513デフォルトの名無しさん
2012/07/16(月) 01:26:02.69 だれか3000円上げるから
24平均律の鍵盤プログラム作ってくれ〜(T_T)
24平均律の鍵盤プログラム作ってくれ〜(T_T)
514デフォルトの名無しさん
2012/07/16(月) 01:27:51.13 作曲するのに使います
音色はピアノ音だけでOKです
音色はピアノ音だけでOKです
515デフォルトの名無しさん
2012/07/16(月) 09:32:19.09 コンパイルしたプログラムなら3'000円でいいけど
ソース(ソース丸見えのVBS…というか鍵盤必要ならHTA)で欲しいなら150'000円
ソース(ソース丸見えのVBS…というか鍵盤必要ならHTA)で欲しいなら150'000円
516デフォルトの名無しさん
2012/07/16(月) 10:42:01.70517デフォルトの名無しさん
2012/07/16(月) 10:50:19.70 白鍵とか黒鍵は
ないようなもんなんで
ボタンがズラリと並んでるだけでOKです
Eの位置だけボタンにEって書いてくれたらOKです
ないようなもんなんで
ボタンがズラリと並んでるだけでOKです
Eの位置だけボタンにEって書いてくれたらOKです
518デフォルトの名無しさん
2012/07/16(月) 19:11:52.43 よくわからんけど初音ミクじゃだめなの?
519デフォルトの名無しさん
2012/07/16(月) 19:47:57.27 リアルタイムで音を確認しないと何かね……確信持てないっていうか
シーケンスでやってその日は納得いっても
次の日に聞いたらアレ?って事ばかりなんで
シーケンスでやってその日は納得いっても
次の日に聞いたらアレ?って事ばかりなんで
520デフォルトの名無しさん
2012/08/05(日) 23:38:48.37 煽り潰しですね
521デフォルトの名無しさん
2012/08/27(月) 21:54:39.96 知恵袋にも登録したのですが、どうしても知りたいのでご教示お願い致します。
マクロを実行して、他のファイルのマクロまで編集できますか。
いろいろグーグルで調べたのですが、どうもヒットせず実行できそうにありません。
作成したいファイルは追記します。
1.エクセルファイル内にボタンフォームを作り(このファイルを便宜上、ファイル@とする)、ボタンフォームを押すと新しいエクセルファイルが作成される(このファイルを便宜上、ファイルAとする)。
2.次にファイル@から1.とは別のボタンフォームを押すと、「挿入>図>ファイルから」と同じ要領で画像を選択でき、Aファイル内のSheet1・セルA1に画像が貼り付けられる。
3.最後にファイル@に設置した1.と2.とは別のボタンフォームを押すと、ファイルAのVBScriptにスクリプトが書き込まれる(出来ればVBScriptをパスワード保護出来れば幸いです)。
という流れをファイル@のVBScriptなり、モジュール等を使って行いたいのです。
3にあるマクロは、上書き保存ができなくなるマクロのため、1の段階で保存ができると幸いです。
また、複数ファイルを処理する必要が有るため、同一ファイル名で保存しない仕様を求めています。
マクロを実行して、他のファイルのマクロまで編集できますか。
いろいろグーグルで調べたのですが、どうもヒットせず実行できそうにありません。
作成したいファイルは追記します。
1.エクセルファイル内にボタンフォームを作り(このファイルを便宜上、ファイル@とする)、ボタンフォームを押すと新しいエクセルファイルが作成される(このファイルを便宜上、ファイルAとする)。
2.次にファイル@から1.とは別のボタンフォームを押すと、「挿入>図>ファイルから」と同じ要領で画像を選択でき、Aファイル内のSheet1・セルA1に画像が貼り付けられる。
3.最後にファイル@に設置した1.と2.とは別のボタンフォームを押すと、ファイルAのVBScriptにスクリプトが書き込まれる(出来ればVBScriptをパスワード保護出来れば幸いです)。
という流れをファイル@のVBScriptなり、モジュール等を使って行いたいのです。
3にあるマクロは、上書き保存ができなくなるマクロのため、1の段階で保存ができると幸いです。
また、複数ファイルを処理する必要が有るため、同一ファイル名で保存しない仕様を求めています。
522デフォルトの名無しさん
2012/08/27(月) 22:31:18.85 全部出来ますよ
但し、マルチな上にスレ違いなので、具体的な説明は伏せますが
但し、マルチな上にスレ違いなので、具体的な説明は伏せますが
523デフォルトの名無しさん
2012/08/29(水) 19:05:51.32 VB・・・・・Sなのか?
524デフォルトの名無しさん
2012/08/30(木) 22:38:44.70 ExcelでVBS……
ワークシートにボタンに見せかけたオブジェクトを貼り、
押すとハイパーリンクで外部のVBScriptを実行する
とかならやった事がある
ワークシートにボタンに見せかけたオブジェクトを貼り、
押すとハイパーリンクで外部のVBScriptを実行する
とかならやった事がある
525デフォルトの名無しさん
2012/08/30(木) 23:09:40.69 ExcelからVBSを呼ぶだけのパターンか
俺は逆にVBSからExcel.Applicationを使って
Excelブックを操作するってことを結構やるな
「ExcelでVBS」ではなく、「Excel"を"VBSで操作」ってこった
ExcelからVBSを呼ぶくらいなら、そのVBSを標準モジュールなどに取り込んで
わざわざ外部のVBS呼ばずに内部実行するし
俺は逆にVBSからExcel.Applicationを使って
Excelブックを操作するってことを結構やるな
「ExcelでVBS」ではなく、「Excel"を"VBSで操作」ってこった
ExcelからVBSを呼ぶくらいなら、そのVBSを標準モジュールなどに取り込んで
わざわざ外部のVBS呼ばずに内部実行するし
526デフォルトの名無しさん
2012/08/31(金) 10:20:07.61 ってか、VBSならふつうそうでしょ
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 習政権、高市首相への態度硬化 台湾有事発言で連日非難 中国 ★11 [ぐれ★]
- 日本損失1.7兆円に修正 中国渡航自粛の影響試算 [蚤の市★]
- 国内ホテル、既にキャンセルも 訪日客関連業界、事態見守る ★3 [蚤の市★]
- 「どうしようもない」 ため息つくアジアの玄関口 中国の訪日自粛で−福岡市 [蚤の市★]
- NHK、受信料の未払い世帯に督促強化へ 民事手続きの新組織を設置 差し押さえなどの強制執行も ★2 [1ゲットロボ★]
- 橋下徹氏 外務省幹部の訪中受け「口だけ番長」へ痛烈指摘 「喧嘩は日本の完敗…なんとかっこ悪い日本か」 [冬月記者★]
- 【実況】博衣こよりのえちえち朝こよ🧪 ★2
- 【実況】博衣こよりのえちえち朝こよ🧪
- Full Count、THE ANSWER、ENCOUNT、Hint-Pot… 日本人をホルホル漬けにしてくれる「Creative2」サイトの魅力 [452836546]
- カカロット、腰痛い
- 【!?】高市早苗「靖国神社電撃参拝プラン」浮上!これもう戦争だろ… [481941988]
- 【超悲報】中国への武力行使、世論調査で「賛成」「どちらかといえば賛成」48.8% 「反対」「どちらかといえば反対」の44.2%を上回る [314039747]
