1 名前:デフォルトの名無しさん mailto:sage [2012/07/12(木) 19:03:00.57 ] VBAを使った質問ならなんでもござれ 本来の対象であるオフィスアプリを操作する以外の話もOK ゲーム作り、Webアクセス、外部アプリの操作 COM(ActiveX)、Win32API、.NET Framework、DirectXなどなど VBAで実行するものであればなんでも質問してください VBAを開発環境としていろいろ作っちゃいましょう 関連スレ Excel VBA 質問スレ Part25 toro.2ch.net/test/read.cgi/tech/1341722983/ Access VBA 質問スレ Part1 toro.2ch.net/test/read.cgi/tech/1328536426/ VBプログラマ質問スレ(Ver.6.0 まで) part58 toro.2ch.net/test/read.cgi/tech/1328782534/
2 名前:デフォルトの名無しさん mailto:sage [2012/07/12(木) 19:22:31.85 ] 乙
3 名前:デフォルトの名無しさん mailto:sage [2012/07/12(木) 19:23:33.44 ] VBAでQRコードを表示したいです。 入力されたテキストからQRコードを作って、 正方形に配置したセルを白黒に塗り分ければ良いと思うのですが、 具体的にどこから手をつければ良いのかわかりません。
4 名前:デフォルトの名無しさん mailto:sage [2012/07/12(木) 19:24:18.17 ] ieの画面操作で困っています。 操作したいie画面は左右にフレームが分割されているもので、左側に メニューが並んでおり、そのメニューをクリックすると、右フレームに そのメニューに応じた画面が表示されるというものです。 ie画面操作を自動化したいのですが、このメニュー選択の部分が突破 できずにいます。左フレームのソースのリンク先を使って、以下の マクロを書いたのですが Dim objShell As Object Dim IEurl As String Set objShell = CreateObject("WScript.Shell") IEurl = "******************** " objShell.Run IEurl このマクロでは、右フレーム上に画面を開くことができずに 「不正な画面遷移が検出されました」と分割フレームが消えて 全面に表示されてしまいます。 尚、クッキーを引継ぐ必要があるので、WScript.Shellを使っています。 objShell.Run IEurl の部分でカレントフレームを指定するなどが できないでしょうか?Runの前(又は後)に「.〜」と何か挿入するとか・・。 frame(0)などを入れてもうまく行きません。 どなたかie画面操作に詳しい方、レスお願い致します。
5 名前:デフォルトの名無しさん mailto:sage [2012/07/12(木) 19:25:59.48 ] |....,,__ |_::;; ~"'ヽ | //^''ヽ,,) | i⌒" | ∀`) < 誰もいない きのこるならいまのうち |⊂ | ノ _,,,......,,__ /_~ ,,...:::_::;; ~"'ヽ (,, '"ヾヽ i|i //^''ヽ,,) ^ :'⌒i i⌒" |( ´∀`) < きのこ のこーのこ げんきのこ ♪ |(ノ |つ | | ⊂ _ ノ ""U _,,,......,,__ /_~ ,,...:::_::;; ~"'ヽ (,, '"ヾヽ i|i //^''ヽ,,) ^ :'⌒i i⌒" (´∀` )| < エリンギ まいたけ ブナシメジ ♪ ⊂| (ノ | | | ヽ _ ⊃ .U"" | | ミ | ミ サッ! | ミ |
6 名前:デフォルトの名無しさん mailto:sage [2012/07/12(木) 19:27:00.23 ] このスレッドは天才チンパンジー「アイちゃん」が 言語訓練のために立てたものです。 アイと研究員とのやり取りに利用するスレッドなので、 関係者以外は書きこまないで下さい。 京都大学霊長類研究所
7 名前:デフォルトの名無しさん mailto:sage [2012/07/12(木) 23:29:29.48 ] midi再生をしたいのですがどうしたらいいのかわかりません。 .midファイルを再生するのではなく、シート上に ド|■■■ レ| ■■ ミ.| ■■■■ のように表記したものを演奏したいのです。 Beepで音階を表現する方法くらいはわかるのですが 実際は和音もあるのでBeepではできません。 あと、ピアノとかフルートなどの音色も変更できるようにしたいです。 宜しくお願いします。
8 名前:デフォルトの名無しさん mailto:sage [2012/07/13(金) 00:01:34.63 ] >>7 シートってことはExcelか?
9 名前:7 mailto:sage [2012/07/13(金) 00:31:13.62 ] >>8 使ってるのはExcel2002です。 ただ実質的には二次元配列データからmidi再生ってことなので Excelはあまり関係ないかも知れませんが。
10 名前:デフォルトの名無しさん mailto:sage [2012/07/13(金) 00:35:24.18 ] >>7 Excel VBA 質問スレ Part25 toro.2ch.net/test/read.cgi/tech/1341722983/ こっちに来いってさ こっちの>>1 には何がスレ違いだのなんだの書かれてるけど その質問もスレ違いじゃなくてちゃんと答えてくれるっていう人がいるから 行ってみたら?
11 名前:デフォルトの名無しさん mailto:sage [2012/07/13(金) 00:44:19.74 ] >>7 「vba 音を鳴らす 音階 音色 -beep」でググれ
12 名前:7 mailto:sage [2012/07/13(金) 00:44:38.86 ] 質問取り下げます
13 名前:デフォルトの名無しさん mailto:sage [2012/07/14(土) 12:42:44.16 ] 本スレ用NGEx URI/タイトル:含む:VBA Word:正規(含む):(正義|謝罪|謝れ|オナニー|早漏)
14 名前:デフォルトの名無しさん [2012/07/22(日) 03:34:14.70 ] CorelDRAWのVBAの質問ってどこですればいい? って 「スレ立てるまでもない質問はここで 120匹目」 に投稿したらここを紹介された。 ここでおk?
15 名前:デフォルトの名無しさん mailto:sage [2012/07/22(日) 09:11:12.16 ] スレ違いではないので質問するのはお好きなように 答えてくれる奴、答えられる奴が居るかまでは保証しないが
16 名前:デフォルトの名無しさん mailto:sage [2012/07/22(日) 11:46:13.23 ] >>14 このスレが立った経緯を考えると 誰も答えてくれないと思うよ^^
17 名前:デフォルトの名無しさん mailto:sage [2012/07/23(月) 00:03:19.90 ] そもそもCorelDRAWのVBAってなんだよ VBAと言えばMS Officeだし、お絵かきソフトならアドビ一択だろ
18 名前:デフォルトの名無しさん mailto:sage [2012/07/23(月) 08:42:31.17 ] 参照設定に追加される奴なんじゃ?まぁ 14が書いてみないことには何ともだけど
19 名前:デフォルトの名無しさん mailto:sage [2012/07/23(月) 13:57:09.79 ] いや、CorelDRAWはVBA装備だったと思う つかさっさと質問書けばいいのに
20 名前:死ね [2012/07/24(火) 07:52:56.79 ] >>19 あ?なにお前、質問書いてほしいのなら書いてくださいとお願いしろや
21 名前:デフォルトの名無しさん mailto:sage [2012/07/24(火) 13:05:51.79 ] また騙されてダム板に飛ばされた訳だが
22 名前:14 mailto:sage [2012/07/26(木) 00:27:11.99 ] 申し訳ありません。 読めもしない英語のチュートリアルを辞書片手に読んでいました。 200近いオブジェクトのうちの、いくつかのオブジェクトの内側の色を、 CMYKで指定する値に変えるというマクロを組みたいのです。 が、それ以前に指定するオブジェクトを選択できないので困っています。 それで今のところ、単純に任意のオブジェクトを選択するだけのマクロを組みたいのですが 以下のコードから If文のところをどういう風に組めばいいのかが分かりません。 ご教授願えませんでしょうか? Sub オブジェクトを選択する() dim sh1 as shape '選択している全てのオブジェクトを検索 For Each sh1 In ActiveSelection.Shapes '下の*に適合したら選択する if ************* Then sh1.CreateSelection msgbox "指定されるオブジェクトを選択できました。" Exit For End If Next sh1 End Sub
23 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 10:29:19.71 ] >>22 エスパーさ〜〜ん、ご指名ですよ〜〜〜〜〜
24 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 10:38:28.39 ] 普通にバックカラーがなんとかだったらってことなんじゃねーの?
25 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 10:44:55.05 ] 普通に一昨日の天気が雨だったらってことなんじゃねーの?
26 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 10:50:33.68 ] CorelDRAWは解らないが、 > いくつかのオブジェクト > 指定するオブジェクト > 任意のオブジェクト が何を指しているのか書かないと始まらないのでは? 丸いものだけとか、何色のものだけとかさ。 というか、人間相手に自然言語でそういうことを理路整然と語れない奴には プログラムやマクロは無理じゃないか? 英語とかVBA語とか、言語の種類を増やす前に、まず小学校で 生活言語(母語)での基礎的な表現や会話能力を身につけた方がいいかもしれない。
27 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 12:58:03.36 ] おっ 住み分けが機能してるようだ 後は分断工作員さんが回答できるだけの知識をつけるだけだな
28 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 14:03:28.28 ] 向こうは問題ないし(当然、不可能なこととかもあるから100%回答されるわけじゃないが)、 こっちは元々回答者居ないでしょ 住み分け派:ExcelVBAスレで順調に回答、向こうでスレ違いになるこっちの質問には興味なし なんでも来い派:こっちは勝手に立てられたスレだから興味なし
29 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 15:29:48.33 ] また騙されてダム板に飛ばされた訳だが
30 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 22:40:19.68 ] 大学の課題で詰まってしまったんですが、ここで質問しても大丈夫ですかね
31 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 22:45:03.86 ] >>30 君の行っている大学には質問できる教員はいないの? それとも君が教員で課題を考える側?
32 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 22:49:22.77 ] >>31 質問しても、自分で考えての一点張りで…。 課題だから自分で調べてやりなさいとのことなんですが、そもそも文章の意味すら理解できなくて…
33 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 23:18:08.48 ] 出来なければ出来ないでいいんだよ、まだ社会人ではなく子供なんだからさ 単位が取れないとか言うかも知れないが、単位を取ることは仕事と違って義務じゃないんだし 他人の力で単位取る事の方がよほど恥ずべき行為 子供のうちから、中身もないのに表面だけ取り繕うこと考えてるとロクな大人にならないぞ そもそも全員が難なくこなせる内容だったら、課題の意味が無い 出来ない人、間違う人を見極めながら講義を進めていくわけだから、出来ない人が居ても何も問題わけで その上で「出来ない人」に分類されるのが嫌ならば、他人を当てにするのではなく自分を磨け
34 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 23:24:08.96 ] 単位はどうでもいいんですけど、できなくてモヤモヤ
35 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 23:34:16.72 ] なんでもいいから早く質問書けや
36 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 23:39:52.65 ] こういうところで回答するくらいしか優越感に浸れる瞬間が無くて 簡単な質問なら答えるべきではないものでも嬉々として答える人が居るから 試しに質問書いてみたら?
37 名前:デフォルトの名無しさん mailto:sage [2012/07/26(木) 23:53:28.09 ] シート1の2000年のデータを初期値として、2050年までの推移を計算し、10年おきに出力して、グラフに表せ という課題なのですが、この初期値として推移を計算するっていうところがわかんなくて困ってます
38 名前:デフォルトの名無しさん mailto:sage [2012/07/27(金) 03:09:58.57 ] midiデバイスは扱いづらいためdx8のダイレクトサウンドを使おうと思うのですが ブックの参照設定を開いた時に自動で変えることは可能でしょうか?
39 名前:デフォルトの名無しさん mailto:sage [2012/07/27(金) 05:26:07.28 ] >>37 Excelの問題というよりも統計の問題ですよ、それ w forecastとか回帰直線とか、そういったのを調べてみたら?
40 名前:デフォルトの名無しさん mailto:sage [2012/07/28(土) 10:38:07.28 ] 質問 最近 Windows 7/Outlook2010 に移って、今までXP/Outlook 2007のでVP スクリプトから実行してたエラーが出てスクリプトが動きません。テストコー ドを書いても同じ結果です。 エラー Object doesn't support this property or method VBA コード Public Sub test_msgbox(str As String) MsgBox str End Sub VBS コード Set myOlApp = CreateObject("Outlook.Application") myOlApp.test_msgbox("test") 何がおかしいのでしょうか?
41 名前:デフォルトの名無しさん mailto:sage [2012/07/28(土) 10:41:33.24 ] そういう時はさ、最低限何というエラーが出て、それはどこなのかぐらい書けよ
42 名前:デフォルトの名無しさん mailto:sage [2012/07/28(土) 12:03:16.34 ] エラーメッセージ書いてある コードは1行だけ
43 名前:デフォルトの名無しさん mailto:sage [2012/07/28(土) 12:42:33.54 ] エラー出て当たり前だと思うのは俺だけか? というか、こりゃスクリプトの質問だからさすがにスレ違いだな "VP"スクリプトではなくVBスクリプトだとしてもねw
44 名前:デフォルトの名無しさん mailto:sage [2012/07/28(土) 22:35:18.85 ] Byval省略すんなや 書く癖を付けろ
45 名前:40 mailto:sage [2012/07/29(日) 03:36:04.31 ] >>42 サンクス >>43 どうしてエラーがでるか教えてください。ちなみに前の環境ではこのエラーは でません。 追加情報ですが、VBA 側のコードは、"ThisOutlookSession" に書いてありま す。ウェブでこのエラーで検索すると"Digital Signatureがないとだめ"的な ことが書いてあったのでSignatureを登録しましたが結果は変りませんでした。 VBスクリプト側にも署名が必要なのかとなと考えてますがその方法が別りませ ん。
46 名前:デフォルトの名無しさん mailto:sage [2012/07/29(日) 14:44:54.50 ] >>7 >>38 俺が以前作ったエクセルから音を出す装置だぜ〜 apiのPlaySoundを使った場合 xlsg.net/cgi-bin/updown2/updown2.cgi?mode=download&id=439 dx8の場合 xlsg.net/cgi-bin/updown2/updown2.cgi?mode=download&id=438 これはmidiデパイスから音を出してるピンボールだぜ(諸事情でコードは見れないぜ) xlsg.net/cgi-bin/updown2/updown2.cgi?mode=download&id=339
47 名前:デフォルトの名無しさん mailto:sage [2012/07/29(日) 15:28:15.90 ] Excelで作ってる以上、見ようとすればコードは丸見えだけどな VBAプロジェクトの保護ってのは、誤改変防止であってソース漏洩防止じゃないから
48 名前:デフォルトの名無しさん [2012/08/17(金) 15:40:09.16 ] excelで惑星の位置を計算したいと思っています。 地心黄経で出したいのですが、参考になるHPがあれば教えてください。
49 名前:デフォルトの名無しさん mailto:sage [2012/08/17(金) 19:03:31.48 ] >>48 msdn.microsoft.com/ja-jp/library/
50 名前:デフォルトの名無しさん [2012/08/29(水) 05:52:09.70 ] エクセルでwavファイルを取り込んでmp3で保存することは可能でしょうか?
51 名前:デフォルトの名無しさん mailto:sage [2012/08/29(水) 07:07:14.33 ] >>50 もちろん可能ですよ WAVファイルを読み込んで、WAV→MP3に変換して、MP3ファイルを保存するだけです WAVやMP3の仕様を入手できればそれほど難しくはありません
52 名前:デフォルトの名無しさん mailto:sage [2012/08/29(水) 09:04:19.89 ] SOXとかのDLL使えば楽勝じゃね?
53 名前:デフォルトの名無しさん [2012/08/29(水) 15:27:24.12 ] ruby2.0がかなりすごいらしい
54 名前:デフォルトの名無しさん mailto:sage [2012/08/29(水) 16:00:34.47 ] 福沢諭吉「脱亜論」 1885年3月16日 時事新報 日本の不幸は中国と朝鮮だ。 この二国の人々も日本人と同じく漢字文化圏に属し、同じ古典を共有しているが、 もともと人種的に異なるのか、教育に差があるのか、 日本との精神的隔たりはあまりにも大きい。 地球規模で情報が行き来する時代にあって、近代文明や国際法について知りながら、 過去に拘り続ける中国・朝鮮の精神は千年前と違わない。 国際的な紛争の場面でも「悪いのはお前の方だ」と開き直って恥じることもない。 もはや、この二国が国際的な常識を身につけることを期待してはならない。 「東アジア共同体」の一員として その繁栄に与ってくれるなどという幻想は捨てるべきである。 日本は、大陸や半島との関係を絶ち、 欧米と共に進まなければならない。 ただ隣国だからという理由だけで特別な感情を持って接してはならない。 この二国に対しても、国際的な常識に従い、国際法に則って接すればよい。 悪友の悪事を見逃す者は、共に悪名を逃れ得ない。 私は気持ちにおいては「東アジア」の悪友と絶交するものである。 _,,,,,,__ __,,,__ ィjj)))))))))!!!!!彡ヽ, /ミ/ ,}彡ヘ |ミ{ -‐ ‐ ‐ ‐- {三=| El==; ゚ ''==. |ミミ,| `レfォ、,〉 :rfォ.、, !iル┤ . { `¨ i ・、¨ ´ `{ゞ'} 支那、朝鮮とは . | '`!!^'ヽ .「´ 付き合うなと忠告しておいたのに。。。 ! ,-ニ'¬-、 ,!|,_ . \´?` / ∧ヘ、 __/〉`ー ' ´ / 〉 \ _, ィ´「∧ / / 」¬ー- 、_ -‐ ´ / / ヽ、/ / iヾ ヽ
55 名前:デフォルトの名無しさん mailto:sage [2012/08/31(金) 06:14:33.68 ] 誤爆にも程がある
56 名前:デフォルトの名無しさん mailto:sage [2012/08/31(金) 06:54:07.85 ] 誤爆じゃなくて荒らしだろ この手の書き込みは、何の脈絡も無く書かれるから誤爆(投稿スレ間違い)っぽくも見えるが 自己主張を拡散するために脈絡のないスレであっても意図的に投稿しているので 誤爆、誤投稿の類ではない やってる本人は、自己の主張の正しさを拡散しようとしてるのだろうけど こういうマナー違反な荒らし宣伝的な投稿を繰り返せば 主張の内容は拡散されても、その主張は荒らしを繰り返すような キチガイの主張としてしか認識されなくなって逆効果なんだけど、たぶんバカだからそこを解ってない
57 名前:デフォルトの名無しさん [2012/08/31(金) 12:26:50.43 ] >>50 エンコードに必須な複数の技術に特許かかってるから無理っぽいぜ
58 名前:デフォルトの名無しさん mailto:sage [2012/09/01(土) 17:56:29.75 ] レイヤー1と2はいける 3は無理ゲー
59 名前:デフォルトの名無しさん mailto:sage [2012/09/14(金) 07:38:02.71 ] コマンドラインのフリーウェアを呼び出す
60 名前:デフォルトの名無しさん mailto:sage [2012/09/18(火) 17:48:54.06 ] OS 7(64bit) excel2010 memory 8G うち使ってんのは1.8Gくらい?(タスクマネージャーで) cpu i5 漠然とした質問になってしまいますが、Excelが応答なしになるのを回避出来る手段は DoEvents以外にどのようのものがあります? 今作ってんのがやたらに応答なしになってしまうもんで^^;
61 名前:デフォルトの名無しさん mailto:sage [2012/09/18(火) 17:53:44.40 ] 応答無しになる原因がわからないと、なんとも言えないよ。
62 名前:デフォルトの名無しさん mailto:sage [2012/09/18(火) 17:57:40.25 ] >>60 応答なしになるミニマムコードを晒してみ
63 名前:デフォルトの名無しさん mailto:sage [2012/09/18(火) 18:15:21.46 ] 期待通り動かすと応答なし状態になるのを改善したいのか、 なぜ応答なしになるのかわからないけど、それを避けたいのか
64 名前:デフォルトの名無しさん mailto:sage [2012/09/18(火) 18:29:14.33 ] >>60 セルを頻繁に書き換えるようなコードの場合は再計算、再描画を止める
65 名前:デフォルトの名無しさん mailto:sage [2012/09/18(火) 19:05:10.60 ] >>61 …確かに >>62 DBとのやり取り部分があったりするので他の環境では実行不可なんです orz >>63 個人的には後者なんですけど、晒せない以上回答は無理ですよね >>64 再計算はありません。シートの切替も無いので再描画云々でもないです ということでスレ汚しすいませんでした
66 名前:デフォルトの名無しさん mailto:sage [2012/09/18(火) 19:24:56.82 ] >>65 そりゃDBの応答待ちなんじゃねーの? ステップ実行してみたら?
67 名前:デフォルトの名無しさん mailto:sage [2012/09/18(火) 19:48:42.30 ] >>65 実行の可不可なんてどうでもいいからソース晒せっての
68 名前:デフォルトの名無しさん mailto:sage [2012/09/18(火) 20:32:32.47 ] 度々スレ汚しすいません ソースの中で無限ループしてるとこがあり、それを修正したら直りました m(__)mです
69 名前:デフォルトの名無しさん mailto:sage [2012/09/26(水) 11:04:16.66 ] テキストファイルがあるとして、そのテキストファイルがUNICODEなのかANSIコードなのかどうかって判定できます?
70 名前:デフォルトの名無しさん mailto:sage [2012/09/26(水) 11:38:17.65 ] 馬鹿には無理
71 名前:デフォルトの名無しさん mailto:sage [2012/09/26(水) 16:06:35.86 ] >>69 基本的には機械的に判別するのは無理 UNICODEの場合、先頭に特殊なバイト列が入ってる場合がある それ以外だと、それぞれのコードで文字として不適切なバイトコードがあるかどうか見る
72 名前:デフォルトの名無しさん mailto:sage [2012/09/26(水) 18:29:04.04 ] >>71 >機械的に判別するのは無理 そうっすかぁorz 今、手元にUNICODEのテキストファイルがあって、バイナリエディタで見れば先頭が FFFEなんでそれを見ればいいのかなと 思ってたんですが、UNICODEもいろいろ種類がありそうですからねぇ 諦めます
73 名前:デフォルトの名無しさん mailto:sage [2012/09/26(水) 18:33:26.19 ] >>72 そりゃBOM(要検索)だ。
74 名前:デフォルトの名無しさん mailto:sage [2012/09/26(水) 23:25:27.72 ] >>72 前に作ったからキーワードだけ ・Openステートメントでバイナリで開く ・Byte型の配列に格納する(InputB と LOF を使う) ・先頭の二要素(2バイト)を確認して、それぞれFF、FEであるか確認する 適当だけどこれでいいと思う
75 名前:デフォルトの名無しさん mailto:sage [2012/09/27(木) 06:19:31.60 ] >>74 thxです。
76 名前:デフォルトの名無しさん mailto:sage [2012/09/27(木) 10:49:38.07 ] >>74 全然良くない。 BOM無しのファイルもあるんだけど。 BOM無しのファイルは絶対に取り扱わないか、BOM無しの場合判定に間違っても良いならそれでいいけど。
77 名前:デフォルトの名無しさん mailto:sage [2012/10/24(水) 04:16:32.77 ] VBA使ってエロ画像取得ってできるの?
78 名前:デフォルトの名無しさん mailto:sage [2012/10/24(水) 08:45:33.09 ] できる
79 名前:デフォルトの名無しさん mailto:sage [2012/10/24(水) 12:11:20.64 ] 自動でエロAAを自動増殖させるプログラムください
80 名前:デフォルトの名無しさん mailto:sage [2012/10/24(水) 21:56:10.26 ] 自動で自動増殖・・・ なんか頭痛が痛くなってくる言い回しだなw
81 名前:デフォルトの名無しさん mailto:sage [2012/10/24(水) 22:24:54.93 ] 最初の自動は最後のくださいにかかってる
82 名前:デフォルトの名無しさん [2012/11/09(金) 21:30:39.40 ] VBAでADSIを利用して、Outllokパブリックフォルダのアクセス権変更を行うことは可能でしょうか? VBAを実行する環境はサーバではなくクライアントマシンで、パブリックフォルダの所有権を持ったユーザでログオンします。 ヒントだけでも頂けると有り難いです。 よろしくお願いします。
83 名前:デフォルトの名無しさん [2012/11/09(金) 21:32:36.89 ] >>82 の追記です。 目的は、大量のアクセス権変更を一括処理化することです。
84 名前:デフォルトの名無しさん mailto:sage [2012/11/09(金) 22:14:07.65 ] >>83 要するに、知りたいのはアクセス権変更じゃなく ディレクトリツリーの一括処理方法なんだろ?
85 名前:デフォルトの名無しさん mailto:sage [2012/11/09(金) 22:34:16.43 ] >>84 はい。 少しぐぐってはみたところ、「サーバ環境での処理にADSIで〜」という記事ばかりがヒットしてきて、 クライアント環境からアクセス権変更などの処理がまず可能なのかが分からなくて。。
86 名前:デフォルトの名無しさん mailto:sage [2012/11/10(土) 15:18:18.32 ] 可能だよ。少しではなく本気でググればクライアントからのやり方も解説されてるから頑張れ。
87 名前:デフォルトの名無しさん mailto:sage [2012/11/10(土) 16:03:42.22 ] 馬鹿には無理
88 名前:デフォルトの名無しさん [2012/11/10(土) 16:59:51.73 ] 要するに>>87 には無理
89 名前:デフォルトの名無しさん mailto:sage [2012/11/10(土) 18:15:28.02 ] (私みたいな)馬鹿には無理(です)
90 名前:デフォルトの名無しさん [2012/11/10(土) 21:01:03.67 ] 事務職なのだが、職場のWebシステムが出来が悪くて、設計ミスでシステムで治せないから、 データ修正を手入力で何千件もやれとメーカー様から言われた。 頭にきたので、VBA(端末にエクセルしか入ってない)で、IEの自動操作で修正入力しようと 作ってはみたのだが、ふと思ったのだが、これって著作権違反になる? 同じように困ってるほかの組織にプログラムを配るのも、無償、有償かかわらずダメ?
91 名前:デフォルトの名無しさん mailto:sage [2012/11/10(土) 21:17:03.85 ] 何言ってんだ
92 名前:デフォルトの名無しさん mailto:sage [2012/11/10(土) 21:25:49.46 ] >>90 H社?
93 名前:デフォルトの名無しさん [2012/11/10(土) 21:34:33.74 ] >>92 Yes。
94 名前:デフォルトの名無しさん mailto:sage [2012/11/10(土) 21:53:06.02 ] ああ、某ワン・ツーのことね
95 名前:デフォルトの名無しさん mailto:sage [2012/11/10(土) 22:39:35.57 ] 某ワン・ツー とは?
96 名前:デフォルトの名無しさん mailto:sage [2012/11/10(土) 22:51:36.74 ] >>90 誰が何の著作権を違反しているの?
97 名前:デフォルトの名無しさん mailto:sage [2012/11/10(土) 23:01:01.10 ] >>95 某社の社内事務専用システム。
98 名前:デフォルトの名無しさん mailto:sage [2012/11/10(土) 23:06:39.80 ] >>90 プログラムを作ったのはあなたでいいの? 何を参考にした?あるいは何かを丸パクリした? それには他者が権利を主張するどのようなものが関わってる? 細かいところちゃんと書いてくれないと望んでる答えにならないけど、 今書いてる限りではたぶんならないと思うけどね。 あと著作権は余裕があったらさわりだけでも勉強しましょう。 様々なテストケースでちゃんと試してから配れ。 自分とこでちゃんと動いても他所のとこで動かなかったなんてよくある話。 個人で作ったものだし、一気に配らない方がいいかも。 そのプログラムを配布した事でお前さんへの責任が一気に増えることに なってしまうから気をつけなされ。
99 名前:デフォルトの名無しさん [2012/11/12(月) 00:21:59.82 ] >>98 作成したのは自分。Webシステムのhtmlが見えている状態(右クリック禁止処理はされてるが、 IEの通常機能で丸見え)のため、ボタン等の各要素のNameがわかったため、自動操作のコード は作りやすかった。 メーカーのコードを改変しているわけではないし、Webシステムも正規の権限でログイン している。ただ、メーカーのコードを解析し、そのNameを自分のコードで利用しているのは どうなのかなと思ったわけです。またWebシステムの機能を、ログインした後、VBAから自動 操作で、表示された情報を読み書きし、ボタンを押していくって流れなので、入力値のエラ ーチェックや、面倒な計算などは、すべてWebシステムがやってくれてる状態。 Nameを使わないコーディングもできるけど、もうすでに作ってしまった。 又、ただの末端ユーザーのため、テスト環境すらなく、恐ろしいことに ぶっつけ本番。その分、注意して作成してはいる。 メーカー様や、専属SE、システム部門には、頼れない状態。 でも、数千件におよぶ手作業でのシステムの入力だけは、阻止したい。
100 名前:デフォルトの名無しさん mailto:sage [2012/11/12(月) 00:32:16.28 ] 右クリック禁止かぁ、懐かしいよね。 今となっちゃIE、Firefox、Chrome、Opera、Safari 通常用いられるどのブラウザでも普通にメニューに表示されている 開発者用機能で全部見れるんだからさ。
101 名前:デフォルトの名無しさん mailto:sage [2012/11/12(月) 00:41:39.98 ] >>99 ただの末端ユーザの作ったものを他の組織に展開するとか 責任の所在がはっきりしてるならそれでいいんじゃないの? VBAに関係ないからそもそもスレチな気がする
102 名前:デフォルトの名無しさん mailto:sage [2012/11/12(月) 05:42:28.78 ] それ以前に「質問する態度」ではない。内容も文体もね。 単に、自分のスキルをさり気なく自慢したいだけ。
103 名前:83 mailto:sage [2012/11/12(月) 19:58:29.62 ] 遅レスすみません。 >>86 可能であれば頑張って調べて書いてみます。 ありがとうございました!
104 名前:デフォルトの名無しさん mailto:sage [2012/12/07(金) 14:19:59.44 ] VB.NETはおいておいて・・・ VB6とExcel2010とかに付属してるVBAって シンタックス的な違いとかあるのでしょうか?? もしよろしければ違いを明示しているサイトなどを教えてください。
105 名前:デフォルトの名無しさん mailto:sage [2012/12/07(金) 14:22:38.26 ] >>104 違いはない
106 名前:デフォルトの名無しさん mailto:sage [2012/12/07(金) 15:17:40.28 ] >>105 素早い回答ありがとうございます。 言語的な勉強はVBの本でやってみます。 ありがとうございました。
107 名前:デフォルトの名無しさん mailto:sage [2012/12/08(土) 23:14:32.41 ] さっきVBAスレに誤爆しました exlap.rb使ってRubyでマクロ組み込もうとしてます Excel2007で.xlsで保存してるんだけどマクロのセキュリティはあらかじめExcelの方で 有効に設定しなきゃいけないんだよね? 有効にしても動かないしどれ選んでも動かないんだけどどうしてなの?
108 名前:デフォルトの名無しさん mailto:sage [2012/12/08(土) 23:19:30.97 ] >>107 Excel VBA スレで突込みが入ったのは "Excel" の部分ではなく "VB"A の部分が原因だよ。
109 名前:デフォルトの名無しさん mailto:sage [2012/12/08(土) 23:20:02.69 ] ばかすぎた 2007では.xlsmにしなきゃいけないのか 失礼しました
110 名前:デフォルトの名無しさん mailto:sage [2012/12/09(日) 10:19:35.09 ] >2007では.xlsmにしなきゃいけないのか www ま、知らなかったら引っかかるのも当然で、俺も最初は?となったけど
111 名前:デフォルトの名無しさん mailto:sage [2012/12/15(土) 06:56:12.38 ] Excel2007の参照設定をマクロの実行で変更する方法ありませんか? 別言語でExcelを操作しているのでその都度変更できません 具体的にはMicrosoft Scripting Runtimeにチェックを入れたいです ひとつの別言語のプログラムでMicrosoft Scripting Runtimeにチェックを入れるマクロを実行→やりたい処理というように書きたいです
112 名前:デフォルトの名無しさん mailto:sage [2012/12/15(土) 07:33:34.78 ] >>111 References.AddFromFile
113 名前:デフォルトの名無しさん mailto:sage [2012/12/15(土) 07:33:43.99 ] >>111 です 直接書き込むと出来る方法をみつけました ですが,外部から他言語でマクロを組み込もうとすると "C:\Windows\SysWOW64\scrrun.dll"と書いたところが "C:WindowsSysWOW64 crrun.dll"と書き込まれてしまいエラーが出てしまいます これを回避する方法はありますか?
114 名前:デフォルトの名無しさん mailto:sage [2012/12/15(土) 07:34:39.95 ] >>112 書き込んでいる間にかぶってしまいました ありがとうございます それを見つけて実装しているところですが>>113 の問題にぶつかっているところです…
115 名前:デフォルトの名無しさん mailto:sage [2012/12/15(土) 08:03:36.65 ] そんな初歩的なところで躓くなよw
116 名前:デフォルトの名無しさん mailto:sage [2012/12/15(土) 09:26:08.46 ] 解決しました!嬉し
117 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 14:46:50.28 ] 誘導されてしまったので、こっちで再度質問させてもらう。 クラス モジュールで実装したクラスを、クラス名から動的にインスタンス化する方法ってないだろうか。 VBAProject - 標準モジュール + FilesCommon - クラスモジュール + Files + TreeFiles + ListFiles みたいになってるときに、 [TreeFiles] Implements Files ' 〜 [ListFiles] Implements Files ' 〜 [FilesCommon] Sub ShowList(ListType As String) Dim Files As Files Set Files = CreateObject(ListType) ' Filesを使ったリスト化処理 End sub てな感じにして、クラスモジュールの追加と呼び出し文字列(ListType)の変更だけで 挙動を変えたい(ListType の Select Case を作ってそこもメンテさせるってのはちと不味い)のだが、良い方法ないもんかな CreateObjectは当然COMでもなんでもないクラスモジュールを扱えないし、 Appication.EvaluateやCallByNameはNewできないし、 VBScriptのEvalをホスト越しに呼び出してもプロジェクト内部のクラスモジュールまではあずかり知りません、だし、 うまく解決するすべがないものかと・・・。
118 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 15:06:31.62 ] > 質問させてもらう。 > ないだろうか。 何様だよ
119 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 15:18:31.96 ] >>118 質問スレなのだから質問者がいないと成り立たない。 質問する方が立場が上なのは当然である。
120 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 15:28:21.78 ] 「質問」を「生活保護」に変えてみると楽しい事に
121 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 15:36:37.23 ] 自演質問自演誘導 アホかとw
122 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 16:03:55.41 ] ム板は相変わらず成りすましが酷くて話にならんな
123 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 17:14:29.11 ] IDありにすべし
124 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 17:25:26.35 ] >>117 それが仮にできたとして、ListTypeに不正な値が入ってたらどうする気だ?
125 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 18:29:09.00 ] >>124 そんときはエラーになっていい
126 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 19:06:07.30 ] おまいら何時間かかってんだよ。 早く答えろや。
127 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 19:34:23.92 ] >>124 エラーになっていいって事は、エラーにならなくてもいいのか? 想定外のオブジェクト生成されて平気だと? 恐ろしい設計だな
128 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 21:33:40.50 ] >>123 ム板やマ板でID有りにしたところで、大した意味はない ここに来るほどの人ならそんなもん(ry
129 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 22:02:01.69 ] IDを導入したら白濁桃が名無しと使い分けできなくて困るだろ 可哀そうだから反対だわ
130 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 22:14:51.45 ] >>127 ユーザーの入力を受けるわけじゃないから。 そこに入る文字列は、マクロをカスタマイズした人間が決める。 カスタマイズ時の手間を減らしたいだけなんだ。
131 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 23:26:48.27 ] >>117 無理
132 名前:デフォルトの名無しさん mailto:sage [2012/12/24(月) 23:50:17.13 ] >>117 >Sub ShowList(ListType As String) これじゃだめなの? Sub ShowList(Files As Files)
133 名前:デフォルトの名無しさん mailto:sage [2012/12/29(土) 15:01:13.64 ] Excel VBAでマークシート(JPEG画像化済)のOCRを作りたいのですが、 ググってもこれといったヒントが見つかりません ライブラリ的なものでもよいですし、力技でもよいですし、 なにかヒントをいただけないでしょうか?
134 名前:デフォルトの名無しさん mailto:sage [2012/12/29(土) 18:47:50.52 ] >>133 ExcelVBAなんだから、Excel上での処理が基本の言語なんだから なんでそこまで複雑なことをやらせようとするかが不思議だ 勉強したわけでもなんでもないが、VBとかJava、Cとかの メジャーな言語を使うとか、画像処理自体に強いライブラリを持つ言語を 選べばいいんでないの?
135 名前:133 mailto:sage [2012/12/29(土) 19:09:08.47 ] >>134 読み取った結果はExcelで管理して集計とかもExcelでやりたいしExcelで全てできれば便利かな〜、と思ってね VSとかEclipseとかのIDEをインストールするのも手間だし(そもそも知識がないからわからんし)
136 名前:デフォルトの名無しさん mailto:sage [2012/12/29(土) 19:59:20.07 ] >>133 imagingsolution.blog107.fc2.com/blog-category-10.html
137 名前:133 mailto:sage [2012/12/29(土) 21:44:29.92 ] >>136 情報ありがとうございます 画像をセルに表示する発想はなかったのでちょっと面白そうですね ただパフォーマンス的に難がありそうなので外部ツールで二値化と縮小化を行ってから シートに取り込んで処理してみようかと思います
138 名前:デフォルトの名無しさん mailto:sage [2012/12/29(土) 22:05:18.72 ] 二値化とかできるなら後は特定座標が塗られてるかどうか判断するだけだと思うんだがな マークシート読み取りと文字認識は別なレベルの話だぞ
139 名前:133 mailto:sage [2012/12/29(土) 22:10:18.37 ] >>138 その後ググってbmp2csvなるものを見つけました OCRじゃなくてOMRでしたね、間違っててスミマセン
140 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 15:18:27.81 ] 例えば5桁の数値があったとして、その各桁の数字を知るとしたら、 (eg 54289 → 5,4,2,8,9 56→ 0,0,0,5,6) 5桁目を10000で割り商を得て、余りが0でないなら次に1000で割り、…10で割って 商と余りを得る みたいな方法でやっていくしかない?
141 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 15:22:30.58 ] それでいい
142 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 15:54:01.43 ] やっぱりVBAではそれしかないか。ありがとう
143 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 17:01:33.66 ] >>140 あまり変わらないけど、文字列とみなして 1文字目+2文字目+・・・ としたほうがコードがシンプルになるかもね。
144 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 17:09:04.33 ] >>143 最初に文字列とみなし、その長さを調べて、midで分解していくってこと? 上記の例なら 56は2文字だから上3桁は0で残り2文字について調べれば良いのか。 そういう手もあるのか、なるほどです。
145 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 17:16:24.17 ] >>140 の例に上げてる奴に2桁の数字も入ってるから >>143 まんまだと失敗する恐れがある。 左から取得したら駄目だな。 右から1文字目、2文字目〜を取得ということか。
146 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 17:19:04.54 ] 配列設定 数値設定 整数値を取得 ループ開始 10のあまりを配列に出力 再配列 10の商を数値に再格納 数値が0の場合ループ解除 ループ終了 これでいいやないの
147 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 17:24:13.47 ] >これでいいやないの 言語障害ですか?
148 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 18:32:07.25 ] >>147 外国人か? 口語体は義務教育で習う
149 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 18:34:45.45 ] 最大値が99999と決まっているなら 100000を足してからMID関数で2〜6文字目を取り出すのが一番コードがシンプルになるんでない? Format関数でもいいけど
150 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 18:49:27.64 ] どっちでもええやないの
151 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 19:55:03.87 ] >>148 x これでいいやないの o これでええやないの だろ?
152 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 20:00:13.11 ] 言語障害とか以前に精神とか脳を汚染されてるんじゃないだろうかという疑念が
153 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 20:18:35.52 ] 「これでいい」「これでええ」 どっちでも通じるんだよ こういうのって日本語学校ではなかなか教えないからね
154 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 20:30:29.15 ] にゃるほろー 正しい日本語、なんてどこにもないよね 使う人によって違うし、使ううちに変化するし、文化や流行を組み込んでいくものだし VBAスレで自分の知らない日本語の使い方されたからって個人攻撃する その卑しい精神性をまず自覚しろってことですねてんてー
155 名前:デフォルトの名無しさん mailto:sage [2013/01/06(日) 22:20:57.37 ] >>149 なるほど!
156 名前:デフォルトの名無しさん mailto:sage [2013/01/07(月) 12:53:44.27 ] 記録されたマクロを解読しているのですがわからないところがあるので質問させてください A1にもともと書かれているテキストがとても長くてダブルクリックしないと全文は読めない場合 Range("A1").Select ActiveCell.FormulaR1C1 = "A1の長いテキスト全文" Range("B1").Select こうなった時はFormulaR1C1で何が起きているのでしょうか 実際にA1をダブルクリックして全文を読もうとするとマクロは Range("A1").Select ActiveCell.FormulaR1C1 = "あ" With ActiveCell.Characters(Start:=1, Length:=255).Font .Name = "MS Pゴシック" .FontStyle = "標準" .Size = 8……といった感じでフォントの設定が数行入った後で、 Range("B1").Select となるのですが…
157 名前:デフォルトの名無しさん mailto:sage [2013/01/07(月) 12:55:59.85 ] すみません"あ"のところは前半と同じ"A1の長いテキスト全文"です
158 名前:デフォルトの名無しさん mailto:sage [2013/01/07(月) 14:41:35.69 ] FormulaR1C1の位置はプロパティって言って種類や形式を指定する部分だから その部分では何も起きてないし何も起きない。 そのコードを読めればわかるけど セルをダブルクリックする行為はエクセルからしたらそのセルの値を再入力するのと同じ行為ってこと んでもって、>>156 のwith以下はただセルのフォントを指定してるだけだら 今回は省略してもいい部分
159 名前:デフォルトの名無しさん mailto:sage [2013/01/07(月) 14:46:09.17 ] >>156 セルのダブルクリックは「キーボードによるセルの編集開始」なので、それはマクロでは実現できませんし記録もされません そのマクロには「(何もせずに)編集終了」→「カーソル移動」が記録されているだけです
160 名前:デフォルトの名無しさん mailto:sage [2013/01/07(月) 17:09:24.10 ] つまり記録した人はセルをselectして→何もせずに編集終了して→別のセルをselectしたのですね 何もせずに編集終了ってどういう動作をすれば記録されるのでしょうか いろいろ試してるんですけど同じようになりません
161 名前:デフォルトの名無しさん mailto:sage [2013/01/07(月) 19:57:20.18 ] >>160 VBAにそんな機能がないので、どうやっても記録されない
162 名前:デフォルトの名無しさん mailto:sage [2013/01/07(月) 20:28:50.49 ] エクセル2003だとセルA1をダブルクリックすれば Range("A1").Select ActiveCell.FormulaR1C1 = "" の2行が記録される 最後にアクティブを解除するために別のセルクリック
163 名前:デフォルトの名無しさん mailto:sage [2013/01/07(月) 20:40:00.42 ] ぜんぜんトンチンカンなこと言ってた >>160 何もせずに編集終了は別のセルクリック(select)すればいい
164 名前:デフォルトの名無しさん mailto:sage [2013/01/08(火) 00:11:32.61 ] >>160 セルをダブルクリックする目的は、隠れている部分を読むためなんだよね? マクロでセルをSelectするだけでは、隠れた部分は出てこないっていうか、そんな方法はないよ API無しで簡単にやるなら同位置にテキストボックスを貼り付けるぐらいしかないんじゃないかなあ
165 名前:デフォルトの名無しさん mailto:sage [2013/01/08(火) 00:12:58.27 ] そもそもマクロの実行中にセルをキーボードで編集することはできないんじゃ
166 名前:デフォルトの名無しさん mailto:sage [2013/01/08(火) 01:00:52.81 ] sendkey使えば?
167 名前:デフォルトの名無しさん mailto:sage [2013/01/09(水) 15:07:51.75 ] SendkeysでF2を送っても、VBAの実行中はセルの編集はできない(編集状態にならない)
168 名前:デフォルトの名無しさん mailto:sage [2013/01/09(水) 16:08:16.48 ] あんまやったことないけど 恒常ループかけて編集可能にしてみるのは?
169 名前:デフォルトの名無しさん mailto:sage [2013/01/09(水) 16:24:50.75 ] とりあえず右クリックで cancel =TRUE にするかsendkeysの後doeventsでセル編集モードになった 文字送りも可能 シートを最前面に出して実行すればバックグラウンドでコード動かしてても問題なし 必要なら同期処理とればおk
170 名前:デフォルトの名無しさん mailto:sage [2013/01/09(水) 17:18:03.09 ] ってそもそも問題が全然違うんだな 単純に見やすくしたいだけなら ショートカットキーにマクロ割り当てて セルの書式設定を折り返しに、フォント小さくしたり 行や列のサイズをコントロールしたり 見終わったら元に戻すとか がちがちにやるなら表示フォントから文字列サイズ計算して綺麗に並べるとか 透明化フォームに読み出した文字を拡大表示して虫眼鏡ツール作るとか いろいろやり方はあるかと
171 名前:デフォルトの名無しさん mailto:sage [2013/01/09(水) 19:30:41.55 ] 個人で遊んでいるなら良いけどVBAのSendKeysは不安定でバグ含みなので 業務用を考えるなら慎重にな(特に{F2}{NUMLOCK}絡み)お勧めはWSH併用
172 名前:デフォルトの名無しさん [2013/02/03(日) 14:37:06.94 ] 初心者の質問丸なげで申し訳ないです。 excel2002でマクロ組んでいますが、 sheetにある画像のみ印刷するように設定したいと思っています。 そんな方法あるでしょうか? よろしくお願いします。
173 名前:デフォルトの名無しさん mailto:sage [2013/02/03(日) 15:18:48.82 ] >>172 シートのコピーを作って画像以外を消去してから印刷
174 名前:デフォルトの名無しさん mailto:sage [2013/02/03(日) 18:48:17.90 ] >>173 ありがとうございます。できそうな気がしてきました。
175 名前:デフォルトの名無しさん mailto:sage [2013/02/05(火) 23:23:00.31 ] すみません、質問させてください。 Excel2003でUserForm1の中にTextBox1があります。 あるマクロからこのUserForm1をロードして、自動的にTextBox1の中に あるセルのデータ(或いは変数に入っているデータ)を入力させたいのですが、 この様な方法はあるのでしょうか? 宜しくお願いいたします。
176 名前:デフォルトの名無しさん mailto:sage [2013/02/06(水) 00:59:16.93 ] >>175 UserForm1.TextBox1.Text = Sheet1.Range("A1").Value UserForm1.Show フォームがモーダルじゃなくてもいいなら UserForm1.Show False UserForm1.TextBox1.Text = Sheet1.Range("A1").Value
177 名前:デフォルトの名無しさん mailto:sage [2013/02/06(水) 21:47:11.72 ] >>176 ありがとうございます! 逆にモードレスの方が良かったので大変助かりました
178 名前:デフォルトの名無しさん mailto:sage [2013/02/06(水) 22:36:16.80 ] 諸先輩方、どうか教えておくんなまし。 エクセルVBAエディタにて IF文で文字変数がユーロ記号(?)の場合の文を書きたいんですけど、VBAエディタ上で書くと。。。 If str = "?" Then 何かしら実行 End If なのが If str = "?" Then 何かしら実行 End If みたく?マークになってしまいます@Office2007/Win7のVBA エクセルのシートやパワポ上ではふつーに?記号は表示されるのに なにゆえVBAエディタ上だけ?になるのでしょうか? Unicodeとかのコード設定かなと思ったのですがVBAエディタ上で 設定できそうな項目なさそうですし。。 ぜひ教えて下さい!
179 名前:デフォルトの名無しさん mailto:sage [2013/02/06(水) 23:43:04.98 ] >>178 VBAそのものはUnicode対応だが、VBEはしてない ChrWを使え
180 名前:デフォルトの名無しさん mailto:sage [2013/02/07(木) 00:38:30.25 ] >>179 ありがとうございます! msgboxで出してもずっとハテナマークだし半泣きでした。 頂いたヒントでググってたら↓があって読んだら仕組みわかりました。 codezine.jp/article/detail/1718
181 名前:デフォルトの名無しさん [2013/02/13(水) 08:17:48.50 ] VBAでIEを操作し、リンクをクリックしたいんですけど それについて詳しく解説してるサイトとかありますか? ていうか、VBAでIEを操作する際って XXXXXX.Navigate "XXXXX.ne.jp/" このページを開く構文は必ず必要なんですか? 自分でIEのページを開いて、ページを開いた後の処理をVBAにやらせるってことはできないんですか? ページを開いた後の処理をVBAにやらせるには、ページを開くことからVBAにやらせないといけないんですか?
182 名前:デフォルトの名無しさん mailto:sage [2013/02/13(水) 08:44:48.82 ] きみにおあつらえむきのcomponentがある www.activexperts.com/
183 名前:デフォルトの名無しさん mailto:sage [2013/02/14(木) 08:40:10.44 ] 先輩方にご教授願いたい。 ExcelVBAでマクロ作ってるんですが、Win32API関数で、引き数にNULLポインタを渡す場合は どう表記したら良いのでしょう?
184 名前:デフォルトの名無しさん mailto:sage [2013/02/14(木) 10:07:28.80 ] >>183 0
185 名前:デフォルトの名無しさん mailto:sage [2013/02/14(木) 10:26:57.32 ] >>184 有難うございます。 0だと型エラー為ると勝手に思い込んでました。 お恥ずかしい 精進します
186 名前:デフォルトの名無しさん mailto:sage [2013/02/14(木) 18:25:20.83 ] >>185 vbNullString使え
187 名前:デフォルトの名無しさん mailto:sage [2013/02/14(木) 18:27:55.53 ] いや、0のがいいと思う。 memset(ptr, NULL, len) みたいで気持ち悪い。
188 名前:デフォルトの名無しさん mailto:sage [2013/02/14(木) 18:29:15.89 ] >>187 確か、APIの引数にNULLポインタとして渡す目的も、vbNullStringにはあったと思うが
189 名前:デフォルトの名無しさん mailto:sage [2013/03/09(土) 16:39:33.15 ] outlookで予定表をcsv書き出しするとアラームの日付と時刻の項目があるんですけど、 AppointmentItemオブジェクトを見てもReminderプロパティにdateとかtimeがないんですけど どこにセットしろっていう話なんでしょうか。
190 名前:デフォルトの名無しさん mailto:sage [2013/03/09(土) 18:08:31.90 ] msdn.microsoft.com/en-us/library/office/ff184623%28v=office.14%29.aspx www.youtube.com/watch?v=SgmhgeTDc5M
191 名前:デフォルトの名無しさん mailto:sage [2013/03/09(土) 23:11:55.58 ] >>190 レスありがとうございました。とりあえず、引き算して掛け算してReminderMinutesBeforeStartに放り込んで対応しました。
192 名前:デフォルトの名無しさん mailto:sage [2013/03/13(水) 18:07:18.47 ] MSはVB6からVB.NETにしたのにVBAはNETにしないの? 新人にVBAの改造させたら言語が古いとか行って文句を言ってくる
193 名前:デフォルトの名無しさん mailto:sage [2013/03/13(水) 18:26:38.76 ] Excel4Macroで実装させろ
194 名前:デフォルトの名無しさん mailto:sage [2013/03/13(水) 19:03:42.53 ] そいつの得意な言語で作らせる代わりに納期を半分にしたらいい
195 名前:デフォルトの名無しさん mailto:sage [2013/03/13(水) 23:41:33.72 ] 文句を言いながらも、VBAを十二分に使いこなしていくならそれでいい。
196 名前:デフォルトの名無しさん [2013/03/14(木) 03:04:46.29 ] accessで作る出力用レイアウトは、行高と列福を調整するとき、 その左右または上下の枠が自動的にずれないからレイアウトの調整が大変と聞いたのですが、 他の言語でもそうなんですか? 素人にとってはエクセルのように自動でずれてくれるようなイメージが刷り込まれています。 おかしなことを言ってたらすいません。
197 名前:デフォルトの名無しさん mailto:sage [2013/03/14(木) 08:07:18.12 ] >>196 内容ではなく文体がおかしい いや、なんとなく言ってることは解るんだけど、 エスパーしてまで答えるような内容じゃないしな
198 名前:デフォルトの名無しさん mailto:sage [2013/03/14(木) 14:06:05.42 ] それ言語の話じゃなくてエディタの話だしな
199 名前:デフォルトの名無しさん mailto:sage [2013/03/14(木) 20:30:01.45 ] ここはごく数人のヘタレどもがチンシコする糞スレです うまく答えられないときはエラそうになんだかんだいちゃもんつけてきます 看板に偽りスレなので素人が質問しても時間の無駄です わかったら相手にせず黙って去りましょう
200 名前:デフォルトの名無しさん mailto:sage [2013/03/14(木) 21:24:08.29 ] ていうかVBA全く関係ない質問に見えるけど。
201 名前:デフォルトの名無しさん mailto:sage [2013/03/15(金) 17:56:40.86 ] Outlookで予定表の一覧をcmd.exeに出力する方法を教えてください
202 名前:デフォルトの名無しさん mailto:sage [2013/03/15(金) 18:20:57.68 ] CreateObject("WScript.Shell") を使います
203 名前:デフォルトの名無しさん mailto:sage [2013/03/15(金) 21:03:48.32 ] >>201 cmd.exeに出力ってどういう意味だ? とりえあず予定表の一覧なら msdn.microsoft.com/ja-jp/library/office/bb219895 (v=office.12)
204 名前:デフォルトの名無しさん mailto:sage [2013/03/20(水) 12:25:21.26 ] PowerPoint2013で、vbaのマクロをボタンに登録したときの起動が遅いみたいなんですけど事情をご存知の方いませんか。
205 名前:デフォルトの名無しさん mailto:sage [2013/03/20(水) 13:25:02.82 ] 動作がおかしいって話はググるかメーカーへ
206 名前:デフォルトの名無しさん mailto:sage [2013/03/20(水) 19:30:49.66 ] パソコン自体に既に異様に負荷をかけている
207 名前:デフォルトの名無しさん mailto:sage [2013/03/20(水) 19:51:23.45 ] どうもスライドショーモードにしてる時に、マクロの実行までのタイミングでもたついてるみたいです。 始まってしまえば実行速度は2010と変わらないみたいです。
208 名前:デフォルトの名無しさん mailto:sage [2013/03/20(水) 22:41:26.67 ] ワード2003で、フォームに入力した郵便番号、住所、氏名をテキストボックスに入力するVBAを作ったのですが、 氏名だけOKボタンを2回押さないと反映されません。なぜこうなるのでしょうか。 ワード2013では一度に反映されますが、2003で使う必要があるので困っております。 以下に参考までに実物をアップロードしました。どうかご確認・ご教授の程お願いします。 www.dotup.org/uploda/www.dotup.org4059350.doc.html
209 名前:デフォルトの名無しさん mailto:sage [2013/03/21(木) 06:10:43.68 ] 了解
210 名前:デフォルトの名無しさん [2013/03/27(水) 06:37:11.96 ] 質問です。 EXCELのVBAでアプリを操作したいのですが、できますか? したいことの大まかな流れですが、下記のURLでダウンロードできる「アマチュア局インターネット申請」のアプリを起動し、作業を自動でさせたいのです。 www.denpa.soumu.go.jp/public/prog/index.html アプリは総務省提供のものです。 具体的な行いたい作業としては @アプリを起動 A「確認」のダイヤログで「キャンセル」を選択 B新しく開いたウィンドウで「ファイルから読み込む」を選択 C「選択」のダイヤログでエクセル上にあるパスのファイルを選択 これを繰り返したいのです。 EXCELのVBAについては基本的な知識はあります。 よろしくお願いします。
211 名前:デフォルトの名無しさん mailto:sage [2013/03/27(水) 07:10:35.43 ] >>210 じゃああとはWinAPIの知識だな 主にウインドウハンドルと、ウィンドウメッセージについて勉強してこい 大まかに話すと、該当アプリのウィンドウハンドルを取得して 操作するコントロール(ボタンや入力ボックスなど)のハンドルを取得して そのハンドルに操作メッセージを送れば良いだけだ あるダイアログのOKボタンのハンドルが12345だとしたら ハンドル12345にクリックメッセージを送れって命令を書いてやると、そこに マウスカーソル持って行かなくてもそのボタンをクリックしたことになる ただ、この手のものはプログラムで申請の自動化とかすると、不正(提供者が意図しない不正規の手順)な申請とかで プログラム作った奴が訴えられかねないから、自己責任&具体的なコード回答は無しで頑張るしかないぞ
212 名前:デフォルトの名無しさん mailto:sage [2013/03/27(水) 14:01:02.51 ] >>210 (1)〜(4)を繰り返すと、大量にアプリケーションが起動することになると思うのだが、やりたいのは それなのか? 仮に、申請までを繰り返したい場合、法的/道義的にそれは許されるものなのか? 申請を受け付けるサーバへの攻撃と取られる可能性があるぞ。
213 名前:デフォルトの名無しさん mailto:sage [2013/03/27(水) 16:54:29.77 ] スレ誘導 toro.2ch.net/test/read.cgi/tech/1363042502/
214 名前:210 [2013/03/28(木) 07:38:38.73 ] 回答ありがとうございます。 まず、私がこの操作を自動化させたい目的ですが ファイルから読み込んだブラウザのウィンドウを連続印刷したいからです。 印刷処理の部分については自分でコードを作れると思いますので省いておりました。 このアプリを使って既に申請されている局の申請ファイルを読み込むと 申請した内容が整理された形でブラウザに表示されます。 WinAPIの知識ですか。 まずはネットで調べてみたいと思います。
215 名前:デフォルトの名無しさん [2013/03/28(木) 15:15:35.91 ] WSH
216 名前:デフォルトの名無しさん mailto:sage [2013/04/04(木) 17:55:38.87 ] すみません、下記コードを修正して頂きたいのですがお願いできませんでしょうか? 修正内容はダイアログを表示しないで自動的にtest1.jpgという名前でCドラ直下に保存できればと思います。 Option Explicit 'ファイル保存ダイアログ Private Function GetSaveFileName() As String Dim sfile As String sfile = Application.GetSaveAsFilename(fileFilter:="JPGファイル (*.jpg), *.jpg") If sfile = "False" Then GetSaveFileName = "" Else GetSaveFileName = sfile End If End Function Private Sub CommandButton1_Click() Dim rg As Range Dim cht As Chart Dim fina As String
217 名前:デフォルトの名無しさん mailto:sage [2013/04/04(木) 17:56:19.24 ] '保存ファイル名を取得 fina = GetSaveFileName If fina <> "" Then '選択範囲を取得 Set rg = Selection '選択した範囲を画像形式でコピー rg.CopyPicture appearance:=xlScreen, Format:=xlPicture '画像貼り付け用の埋め込みグラフを作成 Set cht = ActiveSheet.ChartObjects.Add(0, 0, rg.Width, rg.Height).Chart '埋め込みグラフに貼り付ける cht.Paste 'JPEG形式で保存 cht.Export Filename:=fina, filtername:="JPG" '埋め込みグラフを削除 cht.Parent.Delete End If End Sub
218 名前:デフォルトの名無しさん [2013/04/04(木) 18:02:12.58 ] 馬鹿には無理
219 名前:デフォルトの名無しさん mailto:sage [2013/04/04(木) 18:15:13.26 ] >>216 嫌です
220 名前:桃白白 mailto:sage [2013/04/05(金) 12:52:08.01 ] >>216 桃白白がお願いされちゃう。 Option Explicit 'ファイル保存ダイアログ Private Function GetSaveFileName() As String GetSaveFileName = "c:\test1.jpg" End Function Private Sub CommandButton1_Click() Dim rg As Range Dim cht As Chart Dim fina As String '保存ファイル名を取得 fina = GetSaveFileName If fina <> "" Then Set rg = Selection rg.CopyPicture appearance:=xlScreen, Format:=xlPicture Set cht = ActiveSheet.ChartObjects.Add(0, 0, rg.Width, rg.Height).Chart cht.Paste cht.Export Filename:=fina, filtername:="JPG" cht.Parent.Delete End If End Sub
221 名前:216 mailto:sage [2013/04/05(金) 14:58:35.87 ] >>220 無事動きました 本当にありがとうございました orz
222 名前:デフォルトの名無しさん mailto:sage [2013/04/05(金) 15:08:41.38 ] 最後がm(_ _)mではなくorzなのが回答内容を反映してて良い味出てるな
223 名前:桃白白 mailto:sage [2013/04/05(金) 15:47:21.55 ] >>222 おいやめろ。まるで桃白白がお答えした内容が期待はずれの ものであり桃白白に失望したといわんばかりじゃないか。 そんなことほんとは思ってないくせに。心にもないこと言わないでちょうだい。ふん。
224 名前:デフォルトの名無しさん mailto:sage [2013/04/16(火) 15:03:53.95 ] おまいら最高すぎ。 クラムチャウダー吹き出した。
225 名前:デフォルトの名無しさん mailto:sage [2013/04/26(金) 19:45:29.36 ] VBAというよりも出来た後のことなんですが、、皆さんマクロをどうやって管理されてます? 会社でバージョン管理システムを入れてるところならそれを使ってるんでしょうけど。 今んとこ、出来たマクロに日付を入れて特定のフォルダに入れてるんです( e.g xxx_20130402.xlsm etc) が、やはり別のフォルダに入れて更新 したのを時々忘れてしまったりしてどうしようかなぁ〜と思っています^^;
226 名前:デフォルトの名無しさん [2013/04/26(金) 20:00:41.70 ] VSS
227 名前:デフォルトの名無しさん mailto:sage [2013/04/26(金) 20:34:20.38 ] >>225 最後にマクロ保存のコードを追加したりしてマクロの保存もVBAでやっちゃえば?
228 名前:デフォルトの名無しさん mailto:sage [2013/04/26(金) 21:13:14.06 ] >>227 実行した時に自分自身を特定のフォルダに上書き保存するってことですかね? あぁそういう手もあるか。
229 名前:227 mailto:sage [2013/04/26(金) 22:37:35.63 ] >>228 ファイル名は日付で管理してるということだから 常に上書き保存じゃなくて同じファイル名が存在していないときのみ保存するとか。
230 名前:デフォルトの名無しさん mailto:sage [2013/04/26(金) 22:58:05.30 ] >>229 参考になりました。ありがとう
231 名前:デフォルトの名無しさん mailto:sage [2013/04/27(土) 01:31:45.70 ] 俺の場合 エクセルVBAのマクロなんて、エクセル表の補助作業にしか使わんから もとのエクセル表の管理が出来てればマクロの管理なんて考える必要ない
232 名前:デフォルトの名無しさん mailto:sage [2013/04/27(土) 05:57:56.22 ] 俺はVBAから入ったので、最初のころはExcelに関係ない ウィンドウズアプリケーション的な物もVBAで作っていたから管理が面倒だった そのうちVB6、そしてC#を使うようになったから今は>>231 と同じだが 管理に奔走する奴等のことも理解できる
233 名前:デフォルトの名無しさん mailto:sage [2013/05/03(金) 16:24:56.80 ] 標準モジュールに自作したマクロが多くなりすぎて、修正を加えたいマクロを探すのが大変になってしまった 例えば、Sub JISAKU()のように マクロ名JISAKUからマクロを記述した該当モジュールを即座に見つける方法ってありますか?
234 名前:デフォルトの名無しさん mailto:sage [2013/05/03(金) 16:54:08.84 ] 普通に Ctrl + F で Sub JISAKU() と検索すれば良いのでは…。
235 名前:233 mailto:sage [2013/05/03(金) 17:26:52.89 ] >>234 ほんとだ! こんな簡単に検索することができたのか 今まで何という無駄な時間を_| ̄|○ 有り難う!!!!
236 名前:デフォルトの名無しさん mailto:sage [2013/05/04(土) 00:36:10.00 ] その程度で喜んでるようならShift+F2で定義に移動した日にはショック死するんじゃないか
237 名前:234 mailto:sage [2013/05/05(日) 18:45:30.48 ] まさかとは思ったがw 補足だけど、検索後にプロパティウィンドウ (デフォルトなら左上のはず) の該当モジュールが反転するので、 検索対象がどのモジュールにあるのか一発でわかる。 236に便乗するけど、定義に移動したのちに Ctrl + Shft + F2 を押下すると元の位置に戻るので 覚えておくと作業が捗るよ。 (プロシージャの数が増加するほど役に立つ。)
238 名前:デフォルトの名無しさん mailto:sage [2013/05/07(火) 13:34:18.34 ] >>233 VBEが表示されているときにF2キーでオブジェクトブラウザが表示される。 そこで検索したり、"VBAProject"を選択してシートやモジュールを選択して、定義したマクロ一覧なんかをブラウズできる。 (VBAProjectというのはプロジェクト名のデフォルト) VBEで編集中のときは、コード入力ウィンドウの上部に"(declaration)"と表示しているコンボボックスがあるので、そこで編集中のシートやモジュールの関数を選択できる。
239 名前:デフォルトの名無しさん [2013/05/11(土) 15:38:41.96 ] Excel2010まではVBE終了させるとウィンドウの位置や大きさを以前は覚えてくれてたのに Excel2013にしから一切覚えなくなった Excel立ち上げてVBE開くたびにウィンドウが全て消えてるので不便です Access2013のVBEは以前と変わらず覚えてるのだけど、Excel2013VBEの何が原因なんでしょうか?
240 名前:デフォルトの名無しさん mailto:sage [2013/05/14(火) 10:41:53.28 ] エクセルVBAのスレッドで聞いたんですが回答が得られなかったのでこちらに書かせてください。 スマートアートオブジェクトの図についてなんですが、 vba上で、挿入した画像のみをクリアして、初期状態に戻す方法がありましたら教えてください。
241 名前:桃白白 ◆9Jro6YFwm650 [2013/05/15(水) 15:25:00.19 ] >>240 「vba上で」は「挿入した」にかかるのか「戻す」にかかるのか 桃白白よくわかんないんだけど、削除する画像にだけ特別な名前をつけちゃったらいんじゃない? DeleteImage1みたいな。画像を列挙して名前にDeleteが含まれてたらそれを削除みたいな。
242 名前:デフォルトの名無しさん mailto:sage [2013/05/26(日) 17:46:36.07 ] EXCELのVBAを使って、amazonの画像の取得を試みたいんだけど、 たとえば、[B]列セルにamazonの商品ページURLが入力してあって、 そのページ毎にある ec2.images-amazon.com/images/I/ ●●●●._SL500_AA300_.jpg という画像ファイルのURLを検索して[C]列セルに抽出したい場合、 どのようなコードを組めば良いでしょうか? よろしくお願いします。
243 名前:デフォルトの名無しさん mailto:sage [2013/05/26(日) 21:37:10.70 ] 嫌です
244 名前:デフォルトの名無しさん mailto:sage [2013/05/26(日) 23:35:03.88 ] >>242 vba html parser で検索
245 名前:デフォルトの名無しさん mailto:sage [2013/06/19(水) 01:05:06.33 ] 超初心者です。色々調べましたがわかりませんでした。 是非お力をお貸しください。 エクセルで、B列だけ、B2から下へ空白があるまでの文字を テキストファイルに書き出し、1.txtで保存し、 またその下の文字列から次の空白の上までを2.txt・・・と、 名前を付けて保存したいのですが、どのようなコードを組んだら よいかご教授ください。よろしくお願いします。
246 名前:デフォルトの名無しさん mailto:sage [2013/06/19(水) 01:44:34.41 ] >>245 このようなコードです Sub B_n_txt() n = 1 ' ファイルの番号 r1 = 2 ' r1=始まりの行 While Cells(r1, 2) <> "" ' 最後ならプログラム終わり If Cells(r1 + 1, 2) = "" Then ' 区切りを見つける r2 = r1 ' r2=終わりの行 Else r2 = Cells(r1, 2).End(xlDown).Row End If Open n & ".txt" For Output As #1 ' ファイルに書き込む For i = r1 To r2 Print #1, Cells(i, 2) Next Close #1 n = n + 1 ' 次のファイル番号 r1 = r2 + 2 ' 次の先頭 Wend End Sub
247 名前:デフォルトの名無しさん mailto:sage [2013/06/19(水) 01:58:13.00 ] >>246 遅くに作成いただきましてありがとうございました! 早速試してみました。出来たーーー! 手動で大量に保存していたので、本当に助かります。 明日から・・・じゃない今日からの作業が楽しみです。 またの機会がありましたら何卒宜しくお願いいたします。
248 名前:245 mailto:sage [2013/06/19(水) 22:26:35.34 ] まだ一日経っていないのですが、お力いただけないでしょうか。 昨日と似たもので、エクセルで2007で。 <1> M列に数字のデータが昇順に並んでいます。M2からがデータです。 そのM列で同じ数字の列までのB2からのデータをデスクトップに 1.txt、2.txt・・・と保存したいのですが。 たとえばM2〜M4までの数字が同じなら、B2〜B4までのデータを デスクトップに順番に保存するというものです。 B列は半角数字とアルファベットでデスクトップはC:\Users\admin\Desktop\ です。
249 名前:245 mailto:sage [2013/06/19(水) 22:32:49.52 ] <2> そして、>>248 にもうひとつ条件を入れて作成が可能であれば・・・ M列と同じ数字の列数と同じB列のものを抜き出すのですが、 その時、Q列が全角のRなら1R.txtで保存、全角のLなら1L.txtなど、 同じM列の数字の中のものだとわかるような方法で保存したいのです。 (Q列は全角Rか全角Lのみとなっています) たとえばM2〜M4までが同じ数字だが、Q2とQ4がR、Q3がLなら B2とB4のデータを1R.txt B3を1L.txtと保存し、 次のM5〜は上記と同様2R.txt・・・・・と保存していくものが希望です。 何卒よろしくお願いいたします。
250 名前:デフォルトの名無しさん mailto:sage [2013/06/19(水) 22:47:49.25 ] 少し自分で努力しろ。
251 名前:デフォルトの名無しさん mailto:sage [2013/06/19(水) 22:55:24.53 ] >>249 >何卒よろしくお願いいたします。 嫌です
252 名前:245 mailto:sage [2013/06/19(水) 23:05:47.80 ] 努力してみたのですが習得に時間がかかるようで。 不愉快にさせてしまい申し訳ありません。
253 名前:デフォルトの名無しさん mailto:sage [2013/06/19(水) 23:10:27.65 ] 別に不愉快にはなっていない。 果報は寝て待て。
254 名前:デフォルトの名無しさん mailto:sage [2013/06/19(水) 23:53:16.55 ] >>249 俺が作成料2万円でやってやる 仕様の変更や追加は条件一つに付き3000円
255 名前:デフォルトの名無しさん mailto:sage [2013/06/20(木) 07:34:25.85 ] > 努力してみたのですが習得に時間がかかるようで。 最初から努力などしてないくせに
256 名前:245 mailto:sage [2013/06/20(木) 08:35:19.31 ] 切り貼り奮闘し>>248 はなんとか出来ました。 せっぱつまっていたのでお願いしてみましたが、 >>249 は出来ませんでしたので ちまちま手作業で乗り切ろうと思います。 スレ汚しして申し訳ございませんでした。 >>246 さん、本当にありがとうございました。
257 名前:デフォルトの名無しさん mailto:sage [2013/06/20(木) 11:37:32.35 ] >>256 雰囲気こんな感じ。 For i = 2 To maxRow If Cells(i, 17).Value = "R" Then rBuf = rBuf & Cells(i, 2).Value & vbCrLf Else lBuf = lBuf & Cells(i, 2).Value & vbCrLf End If Next Open "1R.txt" For Output As #1 Print #1, rBuf Close #1 Open "1L.txt" For Output As #1 Print #1, lBuf Close #1
258 名前:デフォルトの名無しさん mailto:sage [2013/06/20(木) 18:22:26.64 ] >>257 ありがとうございます。 何故か中身が空っぽで保存されていました。 自動保存から切り貼りしてなんとかやっているようなレベルなので 厳しいですが色々調べながら頑張ります。 本当にありがとう!
259 名前:デフォルトの名無しさん mailto:sage [2013/06/20(木) 18:50:16.31 ] >>258 丁寧な言葉は使ってるけど、言いたいことは >>257 ご苦労さん、全く使えねぇコード書きやがって動かなきゃ意味ねえんだボケ! ってところかw
260 名前:桃白白 ◆9Jro6YFwm650 [2013/06/20(木) 18:55:59.95 ] >>259 うるせえな、ちょっと黙ってろ。
261 名前:デフォルトの名無しさん mailto:sage [2013/06/20(木) 19:41:13.25 ] >>259 ん?俺はお前にレスした覚えはないが。 何かスイッチ押しちゃったw
262 名前:桃白白 ◆9Jro6YFwm650 [2013/06/20(木) 19:44:49.91 ] >>249 でけーた。試してみて。 https://friendpaste.com/1MQf5hd3f08yQhMLmS32c
263 名前:デフォルトの名無しさん mailto:sage [2013/06/20(木) 20:02:44.42 ] 更年期のオッサンってキレやすいんだな
264 名前:デフォルトの名無しさん mailto:sage [2013/06/20(木) 21:21:07.67 ] >>262 桃白白さま。 ありがとうございます!凄いです!魔法使いみたい。 何時間もかかっていたややこしい仕事が一瞬で済むなんて。 作っていただいたコード見てもさっぱりわからない自分が情けないです。 基本から勉強すべきなんだなと痛感しました。 自分で努力しろと助言くださった方々、まさしくその通りです。 みなさんに感謝の気持ちでいっぱいです。ありがとうございました。
265 名前:デフォルトの名無しさん mailto:sage [2013/06/20(木) 21:27:07.06 ] 毎日痛みと戦ってるからな
266 名前:デフォルトの名無しさん mailto:sage [2013/06/20(木) 21:43:16.94 ] >>264 >作っていただいたコード見てもさっぱりわからない自分が情けないです。 この時点でお前のために書いてないと気づけよw
267 名前:デフォルトの名無しさん mailto:sage [2013/06/21(金) 23:13:03.66 ] 生理痛?
268 名前:デフォルトの名無しさん mailto:sage [2013/06/22(土) 00:31:32.15 ] 桃白白 ↑なんてよむにょ?
269 名前:デフォルトの名無しさん mailto:sage [2013/06/22(土) 00:38:54.33 ] オッサンと読めば良いよ
270 名前:デフォルトの名無しさん mailto:sage [2013/06/22(土) 01:37:03.71 ] ググレカス、というか、 ドラゴンボールはすでにオッサン世代しか知らんのか
271 名前:デフォルトの名無しさん mailto:sage [2013/06/22(土) 15:07:38.48 ] ピーチダブルホワイト
272 名前:デフォルトの名無しさん mailto:sage [2013/07/03(水) NY:AN:NY.AN ] >>262 先日はありがとうございました! もうひとつ、質問させてください。 >>262 で保存したものを開くと、 カーソルがデータの最初にある状態で保存されていました。 カーソルをファイルの末尾へ移動して保存する場合、 どういう構文をどこに足せばいいのでしょうか・・・ 色々調べてみましたが自力では無理でした。 申し訳ありませんがよろしくお願いします。
273 名前:デフォルトの名無しさん mailto:sage [2013/07/03(水) NY:AN:NY.AN ] >>272 カーソルをB列の最後のデータに移動 Cells(Rows.Count, 2).End(xlUp).Select
274 名前:デフォルトの名無しさん mailto:sage [2013/07/04(木) NY:AN:NY.AN ] >>273 早速ありがとうございます。 何行目に足せばいいのでしょうか・・・
275 名前:デフォルトの名無しさん mailto:sage [2013/07/04(木) NY:AN:NY.AN ] 好きな所に足しなさい
276 名前:デフォルトの名無しさん mailto:sage [2013/07/04(木) NY:AN:NY.AN ] カツカレーが好きなんですけど、この上に足していいですか?
277 名前:デフォルトの名無しさん mailto:sage [2013/07/04(木) NY:AN:NY.AN ] 抜き出したテキストファイルをプログラムで読み込もうとしたのですが、 読み込めず、開いて末尾にカーソル持っていって、 DELキー何度も連打して上書き保存したら、読み込めたんです。 ってことは、元のB列のデータになにかわからない空白がある? 空っぽの頭で考えたのですが、さっぱりわからなくって。
278 名前:デフォルトの名無しさん mailto:sage [2013/07/04(木) NY:AN:NY.AN ] とりあえず出社してから再度悩んでみます。スレ汚しすみませんでした。 明日のランチはカツカレーに決定。おやすみなさい。
279 名前:デフォルトの名無しさん mailto:sage [2013/07/04(木) NY:AN:NY.AN ] 一体何人の分身がいるんだコイツ?
280 名前:デフォルトの名無しさん [2013/07/04(木) NY:AN:NY.AN ] VBAの文法VB.netに統一されるといいのになぁ。
281 名前:デフォルトの名無しさん mailto:sage [2013/07/04(木) NY:AN:NY.AN ] >>279 下衆の勘ぐり?
282 名前:デフォルトの名無しさん mailto:sage [2013/07/04(木) NY:AN:NY.AN ] >>272 です。 不慣れで何をどう説明したらいいのかすらわからず、 グダグダになってすみません。 >>262 で桃白白さまに作っていただいたVBAの最後の部分、 Sub SaveLR_(filename, value) Dim n As Long n = FreeFile Open filename For Output As #n Print #n, value Close n End Sub データを抽出し、ここでテキストに貼るように作っていただきましたが、 最後の改行だけを無くして保存する方法をお教えください。 よろしくお願いいたします。
283 名前:デフォルトの名無しさん mailto:sage [2013/07/04(木) NY:AN:NY.AN ] >>282 パイパイのコードは知らんが Print # で改行無しなら Print #n, value;
284 名前:デフォルトの名無しさん mailto:sage [2013/07/04(木) NY:AN:NY.AN ] >>283 試したところ、空白が無くなって、いけそうです! 明日会社で試してみます。 今から戻って試したい位です。ありがとうございます。
285 名前: 忍法帖【Lv=2,xxxP】(-1+0:5) mailto:sage [2013/07/12(金) NY:AN:NY.AN ] すみません!教えてください、僕の頭ではサパーリです。 マクロを実行するとDROPBOXの複数のフォルダに保存するマクロを作ったのですが ユーザー名が1つ1つのパソコンで異なり他のPCでこのマクロを実行するとエラーがでます(当たり前ですが・・・) マクロでユーザー名を取得することは可能でしょうか?
286 名前:デフォルトの名無しさん mailto:sage [2013/07/12(金) NY:AN:NY.AN ] >>285 www.ken3.org/vba/backno/vba114.html
287 名前:285 mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>286 情報dです。これではC:\Users\に入り込めませんでした。 他に何か方法はないでしょうか?
288 名前:デフォルトの名無しさん mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>287 Dim WshShell As Object Set WshShell = CreateObject("WScript.Shell") Debug.Print WshShell.SpecialFolders("MyDocuments")
289 名前:デフォルトの名無しさん mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>288 レスありがとうございます。 Dropboxがマイドキュメントフォルダに入っていません。 rootは、C:\Users\ユーザー名\Dropboxになってます。 この場合でも、SpecialFoldersで指定は可能でしょうか?
290 名前:デフォルトの名無しさん mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>289 フォルダを検索して、存在しなければフォルダを作るようなコード書けばいいんじゃね?
291 名前:デフォルトの名無しさん mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>290 Dropbox自体が特殊で場所移動とかできないんですよねー。 なんか無理そうだな orz
292 名前:デフォルトの名無しさん mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>291 Dropbox限定か。 なら、hardsoft.at.webry.info/201111/article_4.html をVBAに書き換えろ。 「dropbox フォルダ 場所 取得」でググったら一番上だ。検索時間1分。
293 名前:デフォルトの名無しさん mailto:sage [2013/07/16(火) NY:AN:NY.AN ] ちなみに、dropboxはドキュメントフォルダの場所を変更できるからな。
294 名前:デフォルトの名無しさん mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>292 >********をVBAに書き換えろ。 WScript.Shellも理解できない人にそんなこと言ったって・・・・・・・・・w
295 名前:デフォルトの名無しさん mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>294 ほら、全コード書いちゃうと荒れるじゃん
296 名前:デフォルトの名無しさん mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>295 hardsoft.at.webry.info/201111/article_4.html を見て何とかなるスキルがあるなら >>289 のような質問自体が生じないってこと。 >>288 に対して >>289 の再質問を見ると SpecialFolders("MyDocuments")が何を返すのかを調べもしていない = 意味不明でもコピペするだけで動くコードがほしい ということでしょう。 [C:\Users\<ユーザー名>\Dropbox]決め打ちで良いのならこの文字列を取得 する方法は上記以外にもいくつもあるよね。 自分ならExpandEnvironmentStringsで%USERPROFILE%を取得とか WScript.Network UserName で<ユーザー名>を取得することを検討するな。
297 名前:デフォルトの名無しさん mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>296 Dropboxのパス取得が目的なら、それでは不十分。
298 名前:デフォルトの名無しさん mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>291 > Dropbox自体が特殊で場所移動とかできないんですよねー。 これはいくら何でもひどい
299 名前:296 mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>297 でしょうね 自分がDropboxを使っていないのとUPするとき長くなるので以下の文章を抜いちゃったんだ 「Dropboxは使っていないので無責任になるが上記URLにDropboxの場所がデフォルトの場合 C:\Users\<ユーザー名>\Dropboxになる。また >>293 ・・・場所を変更できるからな。 とあるので対象PCはすべてデフォルトということを元>>285 は検証しているのだろうか。 >>291 Dropbox自体が特殊で場所移動とかできないんですよねー。 とあるが 特殊なDropboxなのだろうか?それとも移動可能ということを知らないだけなのだろうか?」 もしユーザーが簡単にC:\Users\<ユーザー名>\Dropboxの場所を変更できるのならだれか 元>>285 に引導を渡してやってくれ。
300 名前:デフォルトの名無しさん mailto:sage [2013/07/16(火) NY:AN:NY.AN ] >>299 よくある普通の設定ダイアログで、普通に変えられるよ。
301 名前:デフォルトの名無しさん mailto:sage [2013/07/17(水) NY:AN:NY.AN ] WSH.SpecialFolders("Desktop") の結果から"デスクトップ"と"Dropbox"をReplaceして一旦パスを整えて FileSystemObjectのFolderExistsでフォルダがあるかチェックして フォルダが無ければ終了するかフォルダピッカー出して選択してもらう
302 名前:デフォルトの名無しさん mailto:sage [2013/07/17(水) NY:AN:NY.AN ] そんなにPerlが読めない人たちにばかりなの? Dropboxフォルダが書かれてるファイルがあるから、オープンして内容読んでデコードするだけじゃん。
303 名前:デフォルトの名無しさん mailto:sage [2013/07/17(水) NY:AN:NY.AN ] >>302 どこのどれ?
304 名前:デフォルトの名無しさん mailto:sage [2013/07/17(水) NY:AN:NY.AN ] Dropboxの仕様とか明らかにスレ違いなんでどっか適切なとこ探して移動して下さい
305 名前:デフォルトの名無しさん mailto:sage [2013/07/17(水) NY:AN:NY.AN ] >>303 >>292 のリンク先に正解のPerlコードがある
306 名前:285 mailto:sage [2013/07/17(水) NY:AN:NY.AN ] >>292 パールをVBAへ変換できるPG探してみます。 >>293 本当ですね orz 場所移動できました。すみません。 >>294 頑張ります!>>296 >>296 自分ならExpandEnvironmentStringsで%USERPROFILE%を取得とか WScript.Network UserName で<ユーザー名>を取得することを検討するな。 ここらへんググってみます。 >>298 バカですみません。 >>300 助かりました!
307 名前:デフォルトの名無しさん mailto:sage [2013/07/17(水) NY:AN:NY.AN ] Function GetDropboxPath() As String Dim path As String Dim wsh As Variant Set wsh = CreateObject("Wscript.Shell") path = wsh.SpecialFolders("AppData") & "\DropBox\host.db" Dim fn As Long Dim buf As String fn = FreeFile Open path For Input As #fn Do Until EOF(fn) Line Input #fn, buf Loop Close #fn Dim ary As Variant ary = Split(buf, vbLf) GetDropboxPath = StrConv(decodeBase64(ary(1)), vbUnicode) End Sub decodeBase64は、ここのコードをコピペで。 www.gizcollabo.jp/vbtomo/log/archive/vbqanda_4318_2.html
308 名前:デフォルトの名無しさん mailto:sage [2013/07/17(水) NY:AN:NY.AN ] >>307 添削。 Function GetDropboxPath() As String Dim path As String Dim wsh As Variant Set wsh = CreateObject("Wscript.Shell") path = wsh.SpecialFolders("AppData") & "\DropBox\host.db" If Dir(path) = "" Then Exit Function Dim fn As Long Dim buf As String fn = FreeFile Open path For Input As #fn Line Input #fn, buf Close #fn Dim ary As Variant ary = Split(buf, vbLf) GetDropboxPath = StrConv(decodeBase64(ary(1)), vbUnicode) End Function
309 名前:デフォルトの名無しさん mailto:sage [2013/07/17(水) NY:AN:NY.AN ] バールのようなもの
310 名前:デフォルトの名無しさん mailto:sage [2013/07/17(水) NY:AN:NY.AN ] そのファイルの改行コードがどうなってるのかしらんが Line Input ってLFのみだと改行コードだとみなさないんだっけ?
311 名前:デフォルトの名無しさん mailto:sage [2013/07/17(水) NY:AN:NY.AN ] >>310 「そのファイル」はLFで改行された二行固定(すくなくとも今現在は)。 Line InputはLFを認識しない。
312 名前:285 mailto:sage [2013/07/17(水) NY:AN:NY.AN ] >>308 大変助かりました。ありがとうございました。 仕組みがまったく理解できませんが、理解できるように勉強したいと思います。
313 名前:デフォルトの名無しさん mailto:sage [2013/07/17(水) NY:AN:NY.AN ] あー、これ見ても理解できないんだったら、そもそも書けるわけ無かったね。 別に貶めてるとかそういうことじゃないんだけど。
314 名前:デフォルトの名無しさん [2013/07/17(水) NY:AN:NY.AN ] >>313 うぜーやつ
315 名前:デフォルトの名無しさん mailto:sage [2013/07/18(木) NY:AN:NY.AN ] いっそのことコード作成依頼OK、丸投げ歓迎ってテンプレ入れて、このスレをそんなスレに するってのはどう? 本スレでも、コード書きたくてウズウズしてる人いるみたいだし。 それとも、そんな性質のスレほかにもうある?
316 名前:285 mailto:sage [2013/07/18(木) NY:AN:NY.AN ] 何度もすみませんヒントだけでもいいので教えて下さい。 >>308 さんのVBAをcallで読みだしてCommandで保存できるようにしました。 この時saveを使えば開いてる場所に保存されるのですが、saveasメソッドを使用して指定するとアクセスできませんエラーがでてしまいます。 助けてください orz
317 名前:デフォルトの名無しさん mailto:sage [2013/07/18(木) NY:AN:NY.AN ] >>316 エラーになるというコードを晒せ。
318 名前:デフォルトの名無しさん mailto:sage [2013/07/18(木) NY:AN:NY.AN ] >>315 >>1 にはコード作成依頼はダメとか、丸投げダメとは一切書いていない。 「VBAを使った質問ならなんでもござれ」なんだから何でもいいんじゃないの?
319 名前:デフォルトの名無しさん mailto:sage [2013/07/18(木) NY:AN:NY.AN ] >>318 にほんご むずかしい です よくわからない 「作成依頼」と「質問」はおなじことなんでしょうか
320 名前:ピラフ [2013/07/18(木) NY:AN:NY.AN ] >>319 たとえば、相談に乗って欲しいと男を家に誘い込み、 省エネのためといって電気を消し、じつは・・・むぎゅと いう行動に出た場合、相談とせっくすは完全に同じことであると いうことになると思いますので、作成依頼は質問であるということで いいのではないでしょうか。
321 名前:285 mailto:sage [2013/07/18(木) NY:AN:NY.AN ] こんな感じです!バカですみません!! >>317 Sub CommandButton() Call GetDropboxPath >>308 さんのこれでドロップボックスの保存先呼び出すと解釈しました 'ActiveWorkbook.SaveAs これなら何故か上手くいく。 ActiveWorkbook.SaveAs "\新しいフォルダ\練習.xlsm" ←なので直下のこれを指定したのですが・・・ End Sub
322 名前:デフォルトの名無しさん mailto:sage [2013/07/18(木) NY:AN:NY.AN ] >>321 Functionは値を返す関数で、変数に代入したり式の中で使ったりする。 Call myFunction() だと、戻った値が後で使えない。 Sub CommandButton() ActiveWorkbook.SaveAs GetDropboxPath() & "\練習.xlsm" End Sub とやれば、保存できる。 ファイル保存ダイアログを出したかったり、存在しないフォルダを新規作成してその中に保存したい場合とかは、 さらに別のコードが必要。 これからも、VBAで何かを作っていこうと思うのなら、何かVBAの入門書を読んだ方がいいよ。
323 名前:285 mailto:sage [2013/07/18(木) NY:AN:NY.AN ] >>322 レスありがとうございます。 参考に弄ってみます。 何かおすすめの書籍などありましたら教えて頂けませせんか? 質問ばかりですみません。
324 名前:デフォルトの名無しさん [2013/07/18(木) NY:AN:NY.AN ] 大きな本屋に行って何冊か自分で立ち読みして調べるぐらいのことはしてよ
325 名前:デフォルトの名無しさん mailto:sage [2013/08/28(水) NY:AN:NY.AN ] Outlookのvbaに関する質問大丈夫ですか?
326 名前:デフォルトの名無しさん mailto:sage [2013/08/28(水) NY:AN:NY.AN ] OUTです
327 名前:デフォルトの名無しさん mailto:sage [2013/08/28(水) NY:AN:NY.AN ] 何処でしたらいいですか?
328 名前:デフォルトの名無しさん mailto:sage [2013/08/28(水) NY:AN:NY.AN ] 適したスレで
329 名前:デフォルトの名無しさん mailto:sage [2013/08/28(水) NY:AN:NY.AN ] テキストファイルを指定して直接開きたいのですがどうしたらいいでしょうか? shell関数はexeのみですよね?
330 名前:デフォルトの名無しさん mailto:sage [2013/08/28(水) NY:AN:NY.AN ] >>329 With CreateObject("Wscript.Shell") .Run "C:\hoge.txt", 5 End With
331 名前:デフォルトの名無しさん mailto:sage [2013/08/29(木) NY:AN:NY.AN ] まさかOUTLOOKだけにOUTだす、っていうダジャレですか このクソオヤジがぁ?
332 名前:デフォルトの名無しさん mailto:sage [2013/09/02(月) 21:53:12.79 ] ごちゃごちゃ言わずにその疑問を書けばいい。だれか判る人間が答えるだろ(俺は知らんw
333 名前:デフォルトの名無しさん mailto:sage [2013/09/05(木) 18:05:27.91 ] エクセルとアクセスのVBAをマニュアルページとか見ながらだけど 理解できてて、アクセスからデータを引っ張ってきて、エクセルに貼り付けて そこで表計算させたり、条件にまとめて貼り付けたりとかできるんだけど。 それでこういうのを仕事にできるアルバイトしたいとおもって探してて ネット上では、1500円とか結構高い時給でそれっぽいのの応募があったりするんだけど そういうバイトしたことある人っています?実際どれぐらいのスキルを 求められるんだろう?
334 名前:デフォルトの名無しさん mailto:sage [2013/09/05(木) 18:32:58.66 ] >>333 電話して聞けば?
335 名前:デフォルトの名無しさん mailto:sage [2013/09/05(木) 18:53:07.43 ] >>334 ざっと探すとネットでのみ応募で電話番号がわからないところしか 見つからないんですよね。ネットで中核求人サイトを媒介にして応募して 応募した会社からの連絡待ちみたいな。
336 名前:デフォルトの名無しさん mailto:sage [2013/09/06(金) 13:02:30.82 ] >>335 そのスキルじゃ、20代女子じゃないと難しいかと。
337 名前:デフォルトの名無しさん mailto:sage [2013/09/06(金) 13:45:37.41 ] >>336 ああ、やったことあるんすか?20代女子かぁ。うーむ。男女差別って気がして しまうなぁ。
338 名前:デフォルトの名無しさん mailto:sage [2013/09/06(金) 18:00:08.99 ] >>337 いや、無いけど>>333 読む限りVBAをがっつりやるにはスキル足りなさすぎ。
339 名前:デフォルトの名無しさん mailto:sage [2013/09/06(金) 18:03:28.00 ] >>338 なるほど、もっとスキルがあれば、できるかもですな。 実際に働いたことある人の意見がききたいですが。 なかなかそういう人もいないもんなんでしょうかねぇ。
340 名前:デフォルトの名無しさん mailto:sage [2013/09/06(金) 18:04:18.03 ] やればなんとかなるさ
341 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 11:49:00.50 ] エクセルのみ使ったデータ入力の仕事ならあるだろうけど、時給1500円は無いだろう アクセスを使う仕事はデータ入力のみか、DBの設計開発かで必要なスキルが段違いになるが、333には無理だろう 業務で使うVBA開発を前提とした仕事なら、初心者に毛が生えた程度の333では相手にされないだろう
342 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 12:03:23.48 ] >>341 >アクセスを使う仕事はデータ入力のみか、DBの設計開発か DBの設計開発って具体的にいうと、アクセスでテーブルを作って 用途に応じたクエリを作成する。ぐらいまでのことですか? 例えば、都道府県の各市町村で、「田」のつく名称を都道府県ごとに検出して さらに「田」のつく市町村名の割合などを算出する。 これらをSqlとVBAを併用してエクセルに記述できたら、設計開発っていえます? >業務で使うVBA開発 必要な用途に応じて、エクセルの中にフォームを作ったりボタンを作ってそのフォームや ボタンを押すと必要な動作が行われる、ぐらいまでのことが注文されると作れると VBA開発って感じになります?
343 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 12:13:27.25 ] そういう程度では即戦力として雇って貰える所は無いだろな
344 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 12:18:40.43 ] なるほどねぇ。これ以上だと具体的にどういうレベルなのか。 求人はあるみたいだけど、実際に働いた人の話も聞かないしなぁ。 まぁ、バイトならいつでも辞めれるし、辞めさせられるし、飛び込むだけ 飛び込んでみるのもいいかもですが。
345 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 14:25:37.30 ] 今の職場でエクセルのマクロとテキストエディタ(正規表現込み)を独学で覚えて 作業効率を大幅に向上させてきたけど時給900円のままのワープア派遣Orz
346 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 15:23:13.20 ] >>344 会社側が求めている人材なんてその会社毎に違うんだから その会社に問い合わせないとわかんないな あーだこーだ言ってないで成果物を見せればちゃんと判断してくれるよ
347 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 15:26:56.43 ] >>345 時給制なのになんでそんなことするんだよwあほwww
348 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 21:42:21.69 ] Excel VBA 質問スレから誘導されて来ました。 苦戦しているので、どうかお願い致します。 スペックはXPでExcelは2003です。 現在B1セルに○月1日と日付を入れ、シート名を1日としたものがあります。 これを自動で複製して、B1セル日付を○月2日 ○月3日… シート名を2日 3日…となるように、一ヶ月分のbookを作りたいと思っています。 また、その際に、B1セルとシート名の日付が日曜・祭日に当たる場合、 シート名に色を付けたいのですが、肝心のコードが全く分かりません。 (因みにB1セルの日付はシリアル値で入れていて、 書式で○月○日と表示していて、日付が日曜・祭日に当たる場合は 赤文字になるよう、別シートに祝日リストも作って 条件付き書式で設定してあります。) 一応ウェブを漁って、それらしいコードを拾って動かしてはみたのですが いまひとつ、作りたいものがうまく作れないので こちらで教えていただけないでしょうか。 どうかよろしくお願いいたします。
349 名前:デフォルトの名無しさん [2013/09/07(土) 21:54:30.33 ] shrs
350 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 22:02:50.45 ] >>342 「テーブルを作って」を軽く見てるように思えるけど。そこがデータベースの設計の一番重要な所じゃね? >>業務で使うVBA開発 たとえば、事務所の女の子が勝手にそれらのフォーム作ってちょっと便利なことしてたら、すげーそんなこと できるんだ!って褒められてちょっと大事に扱ってくれるんじゃね?ってレベルのスキルだと思うよ。
351 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 22:04:16.62 ] >>348 お前が何がわからないのかわからない (プログラムで)しなければいけない事を細かく分けて考えて 何がわからないのか特定して、そのわからない事を書け
352 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 22:23:24.01 ] >>342 素人がどんなに上手く料理を作れてもプロの料理人にはなれないのと一緒、やってる仕事の性質が違う
353 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 22:36:49.54 ] >>351 レスありがとうございます。 >お前が何がわからないのかわからない 仕事で関数を使ったExcelシートを作る程度で マクロやVBAなどの知識が全くないので VBAそのものが全く分かりません。 なのでそれらしいコードをwebで拾ってきて使ってみたのですが 思っているものが作れなくて苦戦しています。
354 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 22:37:21.57 ] なんでお前ら若い芽を摘むのにそんなに必死なの?
355 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 22:42:08.80 ] >>348 B1をシリアル値で持っていると言うことは年の情報も持っていると言うことだよね? なら、その月の1日から、翌月の1日から1日引いた日数分だけ シートをコピーしてB1の値だけインクリメントしていく。 あとはB1セルの内容をフォーマットで変えてやって、シート名として設定して、 対象シートのB1セルと休日シートを照らし合わせて休日なら シートを赤くすれば良いだけだと思うんだけど、ここまではいい?
356 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 22:50:05.56 ] いじわる多いのぅww >>348 基礎を学んでないならコードの流用は不可能。 今現在の目的を果たすだけが目的なら丸投げして作ってもらう方がいいわな。 勉強が目的なら、いったん今の目的はあきらめて基礎から勉強したほうがいい。
357 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 23:00:37.83 ] >>348 Excel VBA の話題なのになんでここに誘導されて来るんだよw マクロの記録でシートを複製して出力されるコードに手を加えてみたら? それが無理なら丸投げするしか無理だと思う 今のブックをどっかにアップしてみたら暇な誰かが作って再アップしてくれると思うよ
358 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 23:06:49.36 ] みんなVBA程度に大袈裟だなぁ
359 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 23:09:33.19 ] >>355 すみません、分かりません… >>356 はい、基礎を全く学んでいないので webに落ちているコードを拾ってきて 貼り付ける程度の事しか出来ません… なので丸投げで作って頂けたらとても助かるのですが やはりここでは無理でしょうか… 今現在、作りたいbookが出来上がればそれで十分なのですが。 どうかよろしくお願いします。
360 名前:桃白白 [2013/09/07(土) 23:15:42.15 ] >>359 ちょっとまってて。桃白白いまがんばってるから。
361 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 23:17:52.45 ] >>357 あっちはこの手の質問投下すると例外無く荒れるw
362 名前:デフォルトの名無しさん [2013/09/07(土) 23:30:13.52 ] >>348 問題点1:シート名「1日」の複製 −>マクロの記録でコードが取得出来ます。 問題点2:変更するシート名を2日 3日にするには、DAYを使い、日付の数値だけ抽出します。 (マクロでC1セルに =DAY(B1) を登録して、そのコードを見てください。) 抽出した日付に1足して、文字列変換し、”日”を結合します。その後シート名の変更をします。 問題点3:シート名の変更方法 −> マクロの記録で・・。 問題点4:シート名の日付が日曜・祭日かの判定は出来ていて、「赤文字」にしてる様なので、 そのセルの色で if分を使って赤文字かどうかの判定を行い、赤文字ならシートの色を変更します。 (色の数値は、Cells(セル番地).Font.Color で調べられます。) 問題点5:シート名に色を付けたい −> マクロの記録で・・ 問題点6:質問者の疑問には無いが、うるう年の処理(2月が何日までか)。 計算でも出来ますが、現レベルでは別シートに1〜12月の日数表を作成した方が良いかと思います。 参考URL:www.liveway.net/technic/20090625_111050.html の「lastDay」変数が最終日 参考 EXCELで、ある日は祝日(祝日、国民の休日、振替休日等)かを取得する関数 URL:www.excelio.biz/LABORATORY/EXCEL_CALENDER.html 「マクロの記録」が判らないようでしたら、ネットで検索してください。 . VBAの構文等は excelvba.pc-users.net/ の様なサイトが沢山あります、それらを参考にして下さい . そして、どこが判らないのか、どこが思った通りにならないのかを、明確に質問してもらうと的確な解答が得られます。 。 >>357 Excel VBAスレには、嵐がいて、枝の話も幹で質問しろと嘘の誘導をしているので、>>348 はある意味では被害者。
363 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 23:35:26.76 ] うわあ ・・・うわあ
364 名前:デフォルトの名無しさん mailto:sage [2013/09/07(土) 23:48:21.27 ] とりあえず、シートコピーするとこまで作ってやった Sub シートコピー() Dim dt As Date Dim lastday As Integer Dim i As Integer Dim sh As Worksheet dt = Sheets("1日").Range("B1").Value lastday = Day(DateAdd("M", 1, dt) - 1) For i = 2 To lastday Set sh = Worksheets.Add(, Worksheets(i - 1)) sh.Name = CStr(i) & "日" sh.Range("B1").Value = dt + i - 1 sh.Range("B1").NumberFormatLocal = "m月d日" 'シート見出しの色変える処理 Next End Sub 色変えるのは、休日定義してるシートの詳細だせ 内容を理解するまで次の質問は禁止な
365 名前:桃白白 [2013/09/07(土) 23:52:21.26 ] >>359 動きますかしら。 https://friendpaste.com/28NRpEPxYtMlJqM42y0pNW 休日判定はシートを参照したほうがいいのだけれども、どのセルに入ってるのかわからないので とりあえずやっつけで。祝日リストのシート名と範囲と書式を教えてもらえる?
366 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 00:10:20.52 ] こっちも全部作った。ただ、入りきらないから分割するよ。その1 Sub main() Dim firstDay As Date Dim lastDay As Date Dim targetDay As Date On Error GoTo Error_Handler '月初日を取得 firstDay = Range("B1").Value '月末日を取得 lastDay = DateSerial(Year(firstDay), Month(firstDay) + 1, 0) With ThisWorkbook '月初日のシートは既に存在しているので、 '先にシート名とシート色を設定してしまう。 Sheet1.Name = Format(.Sheets(Sheet1.Name).Range("B1").Value, "m月d日") If .Sheets("休日").Cells.Find(firstDay, LookAt:=xlWhole) Is Not Nothing Then .Sheet1.Tab.Color = 255 End If
367 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 00:12:41.86 ] その2 'ひと月分のシートをコピーし、 'シート名、シート色の設定を行う。 For targetDay = lastDay To firstDay + 1 Step -1 .Sheets(Sheet1.Name).Copy After:=Sheets(1) .ActiveSheet.Range("B1").Value = targetDay .ActiveSheet.Name = Format(ActiveSheet.Range("B1").Value, "m月d日") If .Sheets("休日").Cells.Find(targetDay, LookAt:=xlWhole) Is Not Nothing Then .ActiveSheet.Tab.Color = 255 End If Next End With Exit Sub Error_Handler: '例外時はエラー内容を表示する。 MsgBox Err
368 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 00:16:22.53 ] その3 End Sub 休日シート名は「休日」固定で。 違うなら"休日"の部分だけ変えてちょ。
369 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 00:31:40.07 ] 質問させていただいた>>348 です。 みなさま、本当に色々とありがとうございます。 早速試させていただいたのですが >>364 原本の1日のシートと数式を組んであったデータが消え、 日付だけが入った空のシートが複製されてしました… >>365 「型が一致しません」と出てしまいます… >>364 「オブジェクトが不正です」と出てしまいました… なにがいけないんでしょうか、すみません…
370 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 00:36:10.71 ] >>345 かんたん Visual Basic、高橋広樹、2010、技術評論社 ちょっと古いかも知れないが、この本を読んでから決めたら? 1週間で読める入門書 もちろん本屋で、より簡単な、新しい本を探すのもいい >>348 まず、対象月の日数を、知る必要がある 28、29、30、31日? そして、その日数分だけ、シートを作る
371 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 01:12:08.37 ] 済まんかった。今、家で打ち込み直したからもう一度確認して。 その1 Sub main() Dim firstDay As Date Dim lastDay As Date Dim targetDay As Date On Error GoTo Error_Handler '月初日を取得 firstDay = Range("B1").Value '月末日を取得 lastDay = DateSerial(Year(firstDay), Month(firstDay) + 1, 0) With ThisWorkbook '月初日のシートは既に存在しているので、 '先にシート名とシート色を設定してしまう。 .Sheets(Sheet1.Name).Name = Format(.Sheets(Sheet1.Name).Range("B1").Value, "m月d日") If Not .Sheets("休日").Cells.Find(firstDay, LookAt:=xlWhole) Is Nothing Then .Sheets(Sheet1.Name).Tab.ColorIndex = 3 End If
372 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 01:13:07.76 ] その2 'ひと月分のシートをコピーし、 'シート名、シート色の設定を行う。 For targetDay = lastDay To firstDay + 1 Step -1 .Sheets(Sheet1.Name).Copy After:=Sheets(1) .ActiveSheet.Tab.ColorIndex = xlNone .ActiveSheet.Range("B1").Value = targetDay .ActiveSheet.Name = Format(ActiveSheet.Range("B1").Value, "d日") If Not .Sheets("休日").Cells.Find(targetDay, LookAt:=xlWhole) Is Nothing Then .ActiveSheet.Tab.ColorIndex = 3 End If Next End With Exit Sub Error_Handler: '例外時はエラー内容を表示する。 MsgBox Error End Sub
373 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 01:20:34.40 ] 度々すまん。 その1の .Sheets(Sheet1.Name).Name = Format(.Sheets(Sheet1.Name).Range("B1").Value, "m月d日") の行の"m月d日"のm月はいらないな。"d日"にしといて。
374 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 01:31:48.88 ] >>373 いえ、こちらこそ何度もありがとうございます。 今、新しい方を使わせていただいたのですが 今度は「インデックスが有効範囲にありません」と出てしまいました。 >>368 で言われたとおり、祝日リストのシート名を「休日」にしてあるのですが 複製もとの原本である「1日」のシート名も変えるのでしょうか?
375 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 02:00:43.30 ] >>374 そうだね。必要ないね。その1の .Sheets(Sheet1.Name).Name = Format(.Sheets(Sheet1.Name).Range("B1").Value, "m月d日") の部分を取っ払えばいい。 こちらでは動いているんだけどなぁ・・・ 可能性として考えられるのは1日目のシートオブジェクト名がSheet1でないことかな。 トレースでどの行でエラーが発生しているのか教えてくれれば想定付けられるんだけど・・・
376 名前:364 mailto:sage [2013/09/08(日) 02:42:05.75 ] >>369 ああ、すまん。ホントにシートコピーしないとだめなのか Set sh = Worksheets.Add(, Worksheets(i - 1)) の1行を Worksheets("1日").Copy , Worksheets(Worksheets("1日").Index + i - 2) Set sh = Worksheets(Worksheets("1日").Index + i - 1) の2行にさしかえればとりあえず動くはず
377 名前:364 mailto:sage [2013/09/08(日) 02:49:32.23 ] あとコピーなら sh.Range("B1").NumberFormatLocal = "m月d日" の行もいらんかも
378 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 03:15:10.44 ] う、動いたよママン… >>348 です。 みなさま本当にありがとうございます。 とりあえず>>371 さんのコードで. Sheets(Sheet1.Name).Name のところを .Sheets("1日").Name に変えてみたら、無事動かす事が出来ました。 ただ、ひとつだけうまくいかなかったのが シート名の日曜の色付けが出来ませんでした。 祝日の方は、ちゃんと色付け出来てるのですが。 弄るとしたら、どこら辺を弄れば 日曜に当たるシート名を赤くする事が出来るんでしょうか。
379 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 07:04:59.03 ] 度々すみません、>>348 です。 拾ってきたコードなのですが Select Case Weekday(ActiveSheet.Range("B1").Value) Case 1 ActiveSheet.Tab.ColorIndex = 3 Case Else ActiveSheet.Tab.ColorIndex = xlNone End Select これを足してみたら、日曜に該当するシート名も 色付けする事が出来ました。 色々と教えてくださり本当に助かりました、ありがとうございました。
380 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 07:07:59.89 ] >>378 ああ、祝日シートって言う位で、休日は設定されていないのね。 ならバグ対応も含めて、以下のものを使用して下さい。 その1 Sub main() Dim firstDay As Date Dim lastDay As Date Dim targetDay As Date On Error GoTo Error_Handler With ThisWorkbook '月初日を取得 firstDay = .Sheets(Sheet1.Name).Range("B1").Value '月末日を取得 lastDay = DateSerial(Year(firstDay), Month(firstDay) + 1, 0) '月初日のシートは既に存在しているので、 '先にシート名とシート色を設定してしまう。 '.Sheets(Sheet1.Name).Name = Format(.Sheets(Sheet1.Name).Range("B1").Value, "m月d日") If Not .Sheets("休日").Cells.Find(firstDay, LookAt:=xlWhole) Is Nothing Or _ Weekday(firstDay) = vbSunday Then .Sheets(Sheet1.Name).Tab.ColorIndex = 3 End If
381 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 07:09:25.61 ] その2 'ひと月分のシートをコピーし、 'シート名、シート色の設定を行う。 For targetDay = lastDay To firstDay + 1 Step -1 .Sheets(Sheet1.Name).Copy After:=Sheets(1) .ActiveSheet.Tab.ColorIndex = xlNone .ActiveSheet.Range("B1").Value = targetDay .ActiveSheet.Name = Format(ActiveSheet.Range("B1").Value, "d日") If Not .Sheets("休日").Cells.Find(targetDay, LookAt:=xlWhole) Is Nothing Or _ Weekday(targetDay) = vbSunday Then .ActiveSheet.Tab.ColorIndex = 3 End If Next End With Exit Sub Error_Handler: '例外時はエラー内容を表示する。 MsgBox Error End Sub
382 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 07:13:30.14 ] 修正したのは、日曜日の時シートのタブを赤くするのの他に、 実行時に月初のシートが選択されていなくても ちゃんと動くようにしました。 なんかボロボロだな・・・
383 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 07:21:56.09 ] ActiveSheetか
384 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 07:42:16.50 ] >>383 ああ、実行中に手操作で何かシートが選択された場合、 動作がおかしくなるよってことを言ってる? なら、 On Error GoTo Error_Handlerの行の下に Application.ScreenUpdating = Falseを、 End Withの行と、 Error_Handler:の行の下に、 Application.ScreenUpdating = Trueを 付け足しておけばいい。 画面更新がなくなるから、その方が処理も早くなるし。
385 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 08:05:10.27 ] >>384 それしか思い付かないのはまずくね?
386 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 08:16:54.20 ] ActiveSheetをやめる 簡単なことだ
387 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 08:45:44.43 ] えー、でもこうしておけば変な挙動もしないし、ループも一回で済むし。 何で駄目なの?
388 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 09:42:45.98 ] 本人が満足してるならそれでいいんじゃない?
389 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 10:15:48.43 ] あれだろ、シートを変数に突っ込んで使えば Activeなシートを使うみたいに他からの影響を受けないって奴だろ。 別に動作が保証されてるんならどっちでもいいよ。 むしろそういう方法でなければいけないと言う奴は .NetフレームワークとかからExcelオブジェクトをクリエイトした時、同じ処理を.Net側からやらせたい時 どういうコードを組むのかが見もの。
390 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 11:07:35.37 ] はぁ、だめだこりゃ。
391 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 11:27:06.30 ] 白桃以下のが出てきたw
392 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 12:19:00.08 ] >>389 .NETから呼ぶと何か変わるの?
393 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 13:14:07.52 ] ピラフがやれ
394 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 15:42:01.88 ] ピラフは生理中だからだめだ
395 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 16:37:53.61 ] 食べ物がどうして生理になるんだよ
396 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 17:07:00.51 ] すみませんが、excel2007で次のマクロ普通に動いていたのが nextでエラーになってしまいます。 ネットで拾ったもので自分ではさっぱりわかりません。。 誰か助けていただけますでしょうか? 大量のシートの不要行に"1"を立てて非表示化させるマクロです。 Sub macro1() On Error Resume Next Dim w As Worksheet For Each w In Worksheets w.AutoFilterMode = False w.Range("Am:Am").AutoFilter field:=1, Criteria1:="<>1" Next End Sub
397 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 17:18:26.74 ] >>396 ハード-ディスクの内容がすべて消去される可能性のあるコードを実行する気があるのかな? 全くコードを知らないというのはそういうリスクを背負ってることも理解する必要はある。
398 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 17:26:47.88 ] >>396 せめて、どういうエラーがでたかぐらい書け つか、On Error Resume Nextでエラーでるか?
399 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 17:38:06.66 ] >>398 On Error Resume Nextはエラー無視の暴走モードですよね? これで動いてたんですが。。 コードの実行が中断されました というダイアログがでて、 デバックを押すとnextが黄色になっています。 継続を押すと次のシートの処理に移行し非表示は実行されますが、 100シート以上あって繰り返し実行するにはちょっと。。
400 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 17:40:30.78 ] エラートラップの設定次第でエラー出るよ
401 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 17:50:07.72 ] >>399 こっちじゃ再現しないからわからんけど コードの実行が中断されました でググるとなんか情報あるね
402 名前:デフォルトの名無しさん [2013/09/08(日) 17:55:03.18 ] >>401 ググってみます パッと見たところこれという解決策が。。 って感じみたいです。 もちょっと見てます
403 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 18:07:17.76 ] >>399 再現しないな 中断されたあと、継続押したらまたNextで止まるのか? Breakキーの上になんか乗ってないか
404 名前:396 [2013/09/08(日) 18:13:03.97 ] みなさん ありがとうございます。 ググってたらPCの問題かもと思い、 念のため別のPCに移したらエラー出ず無事実行出来ました。 なんかPCにごみが出来ちゃったのかしら。。 コードの問題じゃないことがわかりまして、 みなさん大変お騒がせしてすみっませんでした。
405 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 18:52:21.09 ] 数か月ぶりにここ見るようになったんだが、桃白白はわかるんだがピラフがどういうキャラか意味わからん。。
406 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 18:59:55.59 ] 知る必要があるのかね
407 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 19:03:27.82 ] 生理キャラだろ?
408 名前:デフォルトの名無しさん [2013/09/08(日) 20:23:00.90 ] VBAでIEの操作を試みています。 以下のようなコードができたのですが、IEウィンドウが複数開いているとうまくいきません。 最も最新に開いたウィンドウに対して以下の操作を行いたいのですが、 ヒントでもいいので教えてください。 一応ググってはみましたが、自分の書いたコードにはうまく組み込めず困っています。 Dim IE Dim Word As String Word = "****" With CreateObject("Shell.Application") For Each IE .Windows On Error Resume Next If TypeName(IE.Document) = "HTMLDocument" Then On Error GoTo 0 IE.Document .all . Item("ID") .Value = Word Application .Wait (Now + TimeValue("0:00:03")) Exit Sub End If Next End With End Sub
409 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 20:53:58.78 ] せめてどう上手く行かないのかぐらい書け
410 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 21:24:56.46 ] >>408 タイトルとかURLとかで特定した方がいいんじゃない?
411 名前:デフォルトの名無しさん [2013/09/08(日) 23:04:56.05 ] 開くたびにURLが変わるページでして、 手動でそのページを開いてから、以下のような感じで一番後ろのIEと決め付ける方法で捕捉しようとしているのですが・・・ Dim IE Dim NewIE Dim Word As String Word = "****" Set IE = CreateObject("Shell.Application") Set NewIE = IE.Windows(IE.Windows.Count - 1) For Each NewIE .Windows On Error Resume Next If TypeName(NewIE.Document) = "HTMLDocument" Then On Error GoTo 0 NewIE.Document .all . Item("ID") .Value = Word Application .Wait (Now + TimeValue("0:00:03")) Exit Sub End If Next End With End Sub
412 名前:デフォルトの名無しさん mailto:sage [2013/09/08(日) 23:33:24.25 ] >>411 URLが変わるったって、ホスト名とかパスは変わらないんじゃないの?
413 名前:デフォルトの名無しさん mailto:sage [2013/09/09(月) 00:05:09.46 ] というかよく見たら構文からダメなコードなのね Shell.Applicationの順番って必ずウィンドウを開いた順になるのかな? もしそうならFor Eachで最後まで回せば取れるけど 確実じゃない気がするからやっぱりURLとかで特定したいところ Set IE = CreateObject("Shell.Application") For Each w In IE.Windows If TypeName(w.Document) = "HTMLDocument" Then Set NewIE = w Next
414 名前:デフォルトの名無しさん mailto:sage [2013/09/09(月) 08:28:02.89 ] プロセスの起動日時が一番若いものでいいのでは?
415 名前:デフォルトの名無しさん [2013/09/09(月) 11:03:01.30 ] ExcelのVBAでいろんなExcelファイルから抽出・加工・編集した複数の表データなどを Wordに貼り付けるというマクロを組みたいです。 もちろん表の大きさに応じて、Wordの何ページ目のどこに貼るかというのもVBAでコードを組んで自動処理したいです。 そのために「覚えるべきこと」は何ですか? この目的に沿う「本」や「Web解説サイト」はどこですか?
416 名前:デフォルトの名無しさん mailto:sage [2013/09/09(月) 11:24:55.39 ] >>415 >そのために「覚えるべきこと」は何ですか? 礼儀作法
417 名前:415 [2013/09/09(月) 11:26:14.61 ] 次は?
418 名前:デフォルトの名無しさん mailto:sage [2013/09/09(月) 11:26:27.75 ] ある程度はVBAが使えるってのを前提条件に オフィスの達人〈5〉VBA活用術―Excel/Word/Access/PowerPoint/Outlook Office 2003対応 (オフィスの達人 (5)) [単行本] www.amazon.co.jp/%E3%82%AA%E3%83%95%E3%82%A3%E3%82%B9%E3%81%AE%E9%81%94%E4%BA%BA%E3%80%885%E3%80%89VBA%E6%B4%BB%E7%94%A8%E8%A1%93%E2%80%95Excel-Access-PowerPoint-Outlook-%E3%82%AA%E3%83%95%E3%82%A3%E3%82%B9%E3%81%AE%E9%81%94%E4%BA%BA/dp/4839916055 とかか
419 名前:415 [2013/09/09(月) 11:28:38.31 ] >>418 それは下で質問したけど、中古でも値段が高騰しすぎて困っています。 toro.2ch.net/test/read.cgi/tech/1376371376/323 もっと安い、あるいは最新の本はないですか?
420 名前:デフォルトの名無しさん mailto:sage [2013/09/09(月) 15:25:19.01 ] >>419 値段が高騰するのは、その本に需要があるから 裏返せば、代わりになるような本がない
421 名前:デフォルトの名無しさん mailto:sage [2013/09/09(月) 18:31:50.30 ] 質問じゃなくてクレクレじゃないか 桃白白、出番だぞ
422 名前:デフォルトの名無しさん mailto:sage [2013/09/09(月) 21:25:21.82 ] いや、ないものねだり でしょ
423 名前:デフォルトの名無しさん mailto:sage [2013/09/09(月) 22:48:13.94 ] >>419 MSDNライブラリだと何が不足なの?
424 名前:デフォルトの名無しさん mailto:sage [2013/09/10(火) 22:30:20.32 ] 流れぶった切って質問すまん outlookの送信確認マクロを組んでて、ネットで調べた所 Sub Application_ItemSend(ByVal Item As Object, Cancel As Boolean) For Each Mailto In Item.Recipients CCList = CCList & Mailto.Address & vbCr Next Mailto MSGText = “題名:「” & Item.Subject & “」” & vbCr & “下記が送信予定アドレスです。” & vbCr & CCList & “送信してもよろしいでしょうか?” & vbCr If MsgBox(MSGText, vbExclamation + vbYesNo) = vbNo Then Cancel = True End If End Sub ってマクロで”送信相手のアドレス”と”件名”を表示させることは出来るんだが、
425 名前:424 mailto:sage [2013/09/10(火) 22:31:49.40 ] 続き。 複数アカウントでメールを送信させてて、 「***@****というアドレスから送ります」 ってな感じの記述を加えたいんだ 上の記述から「Mailto.Address」を「Mailfrom.Address」に変えたらいけるかなー と思ったんだが無理っぽい。 だれかわかる人いるかな?
426 名前:デフォルトの名無しさん [2013/09/10(火) 23:50:22.23 ] >>424 発信者アドレスの偽装って事? だとしたら、だれも答えないと思うよ。 なぜって、「オレオレ詐欺」以上に危険な「オレオレ メール」に応用可能。
427 名前:424 mailto:sage [2013/09/11(水) 00:05:13.18 ] >>426 言い方が悪かった・・偽装でもなんでもないんだ。 複数アカウントを登録していて、 現状、Aアドレス、Bアドレスから送信することが出来る状態なんだ。 何も考えずに送信を押すとデフォルト(仮にAアドレス)のアカウントから送信してしまい、 送信する際に 「Aアドレスから送りますがよろしいですか?」 みたいなメッセージボックが出てくれたらいいな、と思ってるんだ リファレンスとかで調べると”宛先””CC””BCC"の表示はできるっぽいけど”FROM”の表示については書かれて無くて・・・
428 名前:デフォルトの名無しさん [2013/09/11(水) 02:25:18.40 ] >>427 「MailItem.SendUsingAccount」プロパティ が使えそう、Outlook無いので検証出来ず。 『MailItem の送信に使用するアカウントを表す Account オブジェクトを設定します。値の取得および設定が可能です。』 だそうです。
429 名前:デフォルトの名無しさん mailto:sage [2013/09/11(水) 04:19:22.15 ] >>425 せめてコードが何やってるか理解してから改変しようぜ 送信者のアドレス出すだけなら If MsgBoxの前に、 MSGText = MSGText & "「" & Item.SenderEmailAddress & "というアドレスから送ります」" を追加すれば行けるんじゃないかな
430 名前:デフォルトの名無しさん [2013/09/22(日) 11:46:30.95 ] EXCELのVBAで質問があります。 シートに直接設定したコンボボックスについて、以下の処理をしたいです。 1.まず選択したセルの値によってコンボボックスの中身(リスト)を 変更する 2.次にコンボボックスでの選択をしたときに、その値を取得する方法 (1.で選択したセルの右セルに表示させたいのです) どのイベントを使えばいいのか分からず、どうもうまく行きません。 何かヒントを頂けますか?
431 名前:デフォルトの名無しさん mailto:sage [2013/09/22(日) 11:56:27.89 ] >>430 1.ワークシートのSelectionChangeイベント 2.コンボボックスのClickイベント
432 名前:デフォルトの名無しさん mailto:sage [2013/09/22(日) 20:58:39.16 ] >>431 >>430 は入力規則で作ったコンボボックス(ドロップダウンリスト)のような気がする。 そうだとしたら、イベント引っ掛けるならWorksheet -> Changeじゃね? 2.なんてあったっけ?
433 名前:430 [2013/09/23(月) 16:20:18.65 ] >>431-432 レスありがとうございます。
434 名前:430 [2013/09/23(月) 16:25:14.81 ] コンボボックスはリストボックスではなくActiveXコントロールを 設定しました。
435 名前:デフォルトの名無しさん mailto:sage [2013/09/23(月) 23:17:31.31 ] >>434 ありがとうございました
436 名前:デフォルトの名無しさん [2013/10/01(火) 08:27:31.37 ] VBAでファイル名を変更したいです。フォルダ・ファイル構成は下のような感じです。 [Folder01] img001.jpg img002.jpg img003.jpg img004.jpg img005.jpg ・ ・ [Folder02] img001.jpg img002.jpg img003.jpg img004.jpg img005.jpg ・ ・ [Folder03] img001.jpg img002.jpg img003.jpg img004.jpg img005.jpg ・ ・ [Folder04] ・ ・
437 名前:436 [2013/10/01(火) 08:28:14.80 ] 何がしたいかと言うと、各フォルダのファイル名のimgXXXが、001から始まっているのですが これを前フォルダの最後のjpgファイルの番号の次の番号から、次のフォルダのjpgファイルの番号を始めたいのです。 フォルダとファイルはたくさんあります。(フォルダは50くらい、各フォルダにファイルは30くらい) どういうコードを書けばいいですか?
438 名前:デフォルトの名無しさん mailto:sage [2013/10/01(火) 08:42:24.31 ] ファイル名用のカウンタ変数を保持してそこからリネームすればいい。
439 名前:436 [2013/10/01(火) 08:45:51.91 ] >>438 なるほど、すばらしいですね! ところでそれってどういうコードをかけばよいのでしょう?
440 名前:436 [2013/10/01(火) 08:46:47.27 ] ちなみにExcelのVBAの標準モジュールというところにコードは書きたいです
441 名前:デフォルトの名無しさん [2013/10/01(火) 11:47:07.85 ] >>437 お前、Excel VBA 質問スレ Part31 で紹介したリンク先を見た上でいってるんだろうな? そこを参照すれば出来るはずだろ? それすらも理解できない?
442 名前:436 [2013/10/01(火) 11:59:06.04 ] >>441 出来ないから聞いておるのだ >>みなさま どなたかわかるかたはいらっしゃらないでしょうか?
443 名前:デフォルトの名無しさん mailto:sage [2013/10/01(火) 12:48:43.47 ] >>442 素直にコードが欲しいと言えばいいのにwww
444 名前:デフォルトの名無しさん mailto:sage [2013/10/01(火) 14:29:08.15 ] > 出来ないから聞いておるのだ アホか 何様のつもりだよガキが
445 名前:デフォルトの名無しさん mailto:sage [2013/10/01(火) 14:58:20.50 ] 質問スレなのだから質問者様が一番偉いのである
446 名前:デフォルトの名無しさん mailto:sage [2013/10/01(火) 16:11:06.71 ] >>445 それをやりたかったら回答料寄こせや 1レス1万でいいぞw
447 名前:デフォルトの名無しさん mailto:sage [2013/10/01(火) 16:29:25.32 ] >>444 > 何様のつもりだよガキが 荒らさないでくれるかな。
448 名前:デフォルトの名無しさん mailto:sage [2013/10/01(火) 16:40:50.01 ] >>447 > 出来ないから聞いておるのだ これを吐いた時点でお前の居場所はない 今更話をそらして逃げようとしても遅い
449 名前:デフォルトの名無しさん mailto:sage [2013/10/01(火) 16:51:48.60 ] >>436 擬似コードだとこんな感じ。再帰使えそう。 sub foo() folders = get_all_folders(path) folders.sort ' 最初のフォルダの最終番号を取得する last_file_name = get_last_file_name(folders(i)) last_number = parse_file_name(last_file_name) ' 次のフォルダの開始番号を計算する first_number = last_number + 1 ' 二個目以降のフォルダ内のファイルを全てリネーム for i = 1 to folders.size - 2 first_number = rename_files(folders(i + 1), first_number) next end sub function rename_files(folder, first_number) as string files = get_all_files_of_folder(folder) files.sort current_number = first_number for i = 0 to files.size - 1 rename files(i), build_file_name(current_number) current_number = current_number + 1 next rename_files = current_number end sub
450 名前:デフォルトの名無しさん mailto:sage [2013/10/01(火) 16:53:06.38 ] 間違えた。 誤:last_file_name = get_last_file_name(folders(i)) 正:last_file_name = get_last_file_name(folders(folders.size - 1))
451 名前:デフォルトの名無しさん mailto:sage [2013/10/01(火) 16:54:06.28 ] さらに間違えてた。 正: last_file_name = get_last_file_name(folders(0))
452 名前:デフォルトの名無しさん mailto:sage [2013/10/01(火) 16:54:58.55 ] おちつけ
453 名前:デフォルトの名無しさん mailto:sage [2013/10/01(火) 17:42:42.63 ] ___ ガスッ |___ミ ギビシッ .|| ヾ ミ 、 グシャッ ∩_∧/ヾヽ | ,| ゚∀゚). .| |;, ゲシッ / ⌒二⊃=| |∵. .O ノ %`ー‐'⊂⌒ヽ ゴショッ ) ) ) )~ ̄ ̄()__ ) ヽ,lヽ) (;;;;;;;;;;;;;;;;;)(_(
454 名前:桃白白 ◆9Jro6YFwm650 [2013/10/04(金) 06:12:18.01 ] >>449 ソートといったらバブルソート、バブルソートといったら桃白白、 桃白白はかわいい、ゆえに桃白白はかわいい。証明終了。 >>442 桃白白もやってみるのだ。ちょっと待っててくれればいいのだ。
455 名前:デフォルトの名無しさん mailto:sage [2013/10/04(金) 10:39:31.16 ] また糞コードを叩く流れか 胸が熱くなるな
456 名前:桃白白 ◆9Jro6YFwm650 [2013/10/04(金) 23:01:49.33 ] >>455 とーなりどーしあなたとあたしたおぱいぱーい♪ >>442 できたのだ。 https://friendpaste.com/3Tm2uY4MkIuhJLIGoaCK6D
457 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 00:41:02.96 ] Sub Sample1() Folder = "C:\images" ' このパス以下を処理 Files = "img???.jpg" ' 処理するファイル名 ChDir Folder Set WSH = CreateObject("WScript.Shell") sCmd = """dir /s /b """"" & Files & """"" 2> nul | sort""" ' ファイルの一覧をソート Set wExec = WSH.Exec("%ComSpec% /c " & sCmd) Do While wExec.Status = 0 ' コマンドの終了待ち DoEvents result = result & wExec.StdOut.Read(100) ' バッファあふれ対策 Loop result = result & wExec.StdOut.ReadAll ' ソート済みの一覧を取得 D = Split(result, vbCrLf) ' 一覧を改行で区切って配列に counter = 1 ' ここから連番リネーム処理 For i = LBound(D) To UBound(D) - 1 ' リストの末尾にも改行があるので1つ減らす NewName = Left(D(i), Len(D(i)) - 7) & Format(counter, "000") & ".jpg" ' 超手抜き注意 Name D(i) As NewName Debug.Print i, D(i), NewName ' 確認 counter = counter + 1 Next End Sub
458 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 00:43:34.39 ] あ、ごめん >>457 は無し 書き込んだ瞬間に大きなバグに気付いた
459 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 00:54:05.80 ] 後半だけ訂正 ' ここから連番リネーム処理 For i = UBound(D) - 1 To LBound(D) Step -1 ' リストの末尾にも改行があるので1つ減らす NewName = Left(D(i), Len(D(i)) - 7) & Format(i + 1, "000") & ".jpg" ' 超手抜き注意 Name D(i) As NewName Debug.Print i, D(i), NewName ' 確認 Next End Sub
460 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 03:13:58.77 ] >>456 ○ num = 0 × num = 1
461 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 03:14:35.26 ] まちがえた >>456 ○ num = 1 × num = 0
462 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 03:15:59.18 ] 間違いだらけの青春
463 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 03:44:35.42 ] >>456 各フォルダのThumbs.dbが巻き込まれて全部jpgにリネームされたんだけど
464 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 08:05:51.30 ] 何で現場には、Option Explicitなしで、一部の変数は宣言せずに使ってる 糞コードがあまりにも多いのか。基本中の基本だろうが。
465 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 08:22:43.71 ] >>464 現場に進言すればいいじゃん。
466 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 19:21:00.77 ] お前の現場が糞現場なだけ
467 名前:桃白白 ◆9Jro6YFwm650 [2013/10/05(土) 23:34:19.45 ] >>461 修正した。Σd(゚∀゚)グッジョブ!! >>463 えーそれは困るよじゃあここをこう修正したらいいよとかそういう提案ある? 桃白白お耳傾けちゃう。
468 名前:デフォルトの名無しさん mailto:sage [2013/10/06(日) 09:21:31.54 ] ありすぎて困る 一から書いた方が早い
469 名前:桃白白 ◆9Jro6YFwm650 [2013/10/06(日) 09:54:54.10 ] >>468 困ることはないでしょう。その中からこれがベストだっていうのをひとつ選べばいいだけなんだから。 恋人選ぶのとはちがうんだよ。教えてよ。
470 名前:デフォルトの名無しさん mailto:sage [2013/10/06(日) 10:22:04.15 ] 取り敢えず桃白とピラフとか言う生理キャラとどっちかにして欲しい。 ベストだって言うキャラのを一つ選んで。
471 名前:桃白白 ◆9Jro6YFwm650 [2013/10/06(日) 10:53:00.49 ] あー話逸らせちゃった。 まあほんとに書けるんだったらとっくに書いてなきゃおかしいわけで できもしないくせに見栄張っちゃったってところかな。
472 名前:桃白白 ◆9Jro6YFwm650 [2013/10/06(日) 10:54:29.47 ] これだけ煽れば桃白白に教えざるをえないよ。策士桃白白。
473 名前:デフォルトの名無しさん mailto:sage [2013/10/06(日) 13:22:21.85 ] ってかさ、未だにトリップキー漏れてるトリをつける神経を疑うわな。 というより本人じゃないやつが成りすましてる可能性が非常に高い。 俺の知ってる桃白白はコードなんか書かなくて、もっと紳士な奴なんだが。 本人に失礼だからいい加減成りすましやめたら?
474 名前:デフォルトの名無しさん mailto:sage [2013/10/06(日) 13:45:02.42 ] 取り敢えず桃白白は尻の穴キャラ ピラフは生理キャラでOK?
475 名前:デフォルトの名無しさん mailto:sage [2013/10/08(火) 23:01:07.19 ] WORDマクロってここで良いのかな? エクセルと違って少ないですよね
476 名前:デフォルトの名無しさん mailto:sage [2013/10/08(火) 23:09:26.96 ] >>475 このスレは間口広いから大丈夫のはず
477 名前:デフォルトの名無しさん mailto:sage [2013/10/08(火) 23:11:48.37 ] >>475 何がですか?
478 名前:デフォルトの名無しさん mailto:sage [2013/10/08(火) 23:24:58.30 ] すみません、スレとかマクロのサンプルが少ないってことです 今、WORDファイルの結合マクロを作ろうと考えているのですが 1つ目のファイル(名前.dot)の内容 [001] cat [002] dog [003] monkey 2つ目のファイル(b.dotx)の内容 (001) ねこ (002) いぬ (003) さる のようになっています これを [001] a.docx cat (001) b.dox ねこ [002] a.docx dog ・・・ のように、ファイル名を付けて並び替えて1つのファイルにしたいのです 何かサンプルなどないでしょうか。 本物はもっと長文で、書式や校正履歴が有るために エクセルでセルに張り付けてソートという方法が使えないのです おねがいします
479 名前:デフォルトの名無しさん mailto:sage [2013/10/08(火) 23:39:36.62 ] だが断る!
480 名前:デフォルトの名無しさん mailto:sage [2013/10/09(水) 00:12:34.20 ] >>478 まず、何がわからないの? ExcelのVBAは使える?
481 名前:デフォルトの名無しさん mailto:sage [2013/10/09(水) 00:42:34.73 ] >>480 あまり使えないです 乱数発生してランダムにソート?とか 文字列の置換、取り出し(Left、Right、Mid)、変換(StrConv)とかくらいならなんとか C、C++とかは少しだけ出来たんですが(MFCはわからないのでWin32APIで) なんだかVBって記号的というか関数名とか変な感じでよく読めないです やろうとしたのは、まずファイルa.doxから Selection.MoveEndUntil Cset:="[", Count:=wdForward みたいにして、[の前までを選択してファイルの一番上にコピペ 次はb.dox(の前までを選択してファイルの一番上にコピペ これを交互に繰り返せば行けるのではないかと思ったのですが…
482 名前:デフォルトの名無しさん mailto:sage [2013/10/09(水) 00:58:59.94 ] 名前.dot b.dotx a.docx b.dox 訳がわからん
483 名前:デフォルトの名無しさん mailto:sage [2013/10/09(水) 01:01:11.58 ] おっと a.dox ってのも追加か
484 名前:デフォルトの名無しさん [2013/10/09(水) 20:28:46.52 ] >>478 WordのVBAはあまり使わなかったが、下の様なフローで出来た、Word2007使用。 1:文書a.docxを開く、全文を変数に代入、文書a.docx閉じる、各行に分割し配列に記録 2:文書b.docxを開く、同上 3:VBA入りの結合用ファイルをアクティブに 4:配列上で各行に分割 5:カッコの位置を工夫し、ファイル名を入れた物をWordに書き出し 6:Word上で、ソート 7:Word上で、各行のカッコの位置を戻す WordのVBAは、慣れていないから難解。
485 名前:デフォルトの名無しさん mailto:sage [2013/10/09(水) 20:37:56.64 ] 書式と校正履歴はどこ行った
486 名前:484 [2013/10/09(水) 20:43:02.94 ] 書式と校正履歴が必要なんだ、じゃだめだ。 あぁ勘違いでした。
487 名前:484 [2013/10/09(水) 23:16:42.80 ] WordのVBAだけでやると、校正履歴・書式も残る物が出来た、 Wordは変な癖が有るし、いゃ〜めんどくさい、WordのVBAなんかもう触りたくない。 でもいい勉強になった。
488 名前:デフォルトの名無しさん mailto:sage [2013/10/09(水) 23:44:09.07 ] WordはVBAじゃなくてもよく分からないからな。 余り好きじゃない。
489 名前:デフォルトの名無しさん mailto:sage [2013/10/16(水) 08:28:03.32 ] エクセル2003です。 コマンドボタンを直接エクセル画面に貼り付け➡コマンドボタンのプロシージャにプリントアウトのプログラムを記入➡コマンドボタンをクリック➡コマンドボタンが左側にかってに移動(プリントアウトは出来る) コマンドボタンが左側に移動しない方法を教えて下さい。
490 名前:デフォルトの名無しさん mailto:sage [2013/10/16(水) 09:38:11.85 ] >>489 普通の「→」を使わないのが気に障るから教えない
491 名前:デフォルトの名無しさん [2013/10/16(水) 13:43:15.14 ] 効いてる効いてるw
492 名前:デフォルトの名無しさん mailto:sage [2013/10/16(水) 13:48:09.87 ] 2003ってサポート終了するポンコツじゃん。 いまさらそんなの使えるようになっても食っていけないよ。
493 名前:デフォルトの名無しさん mailto:sage [2013/10/16(水) 18:27:10.73 ] >>491 お前は早く普通の→を入力できるように頑張れよw
494 名前:デフォルトの名無しさん mailto:sage [2013/10/16(水) 18:55:25.96 ] iPhoneからの入力だと 最初に出るね。➡︎。
495 名前:デフォルトの名無しさん mailto:sage [2013/10/16(水) 21:51:27.03 ] Appleは、そういう独善的なところが嫌い。 そういうマシンに心酔するユーザも嫌い。
496 名前:ピラフ [2013/10/20(日) 02:37:44.24 ] >>495 ピラフのことは?好き?
497 名前:デフォルトの名無しさん mailto:sage [2013/10/20(日) 02:45:46.58 ] たまにキチガって暴れるから嫌い。
498 名前:デフォルトの名無しさん mailto:sage [2013/10/20(日) 06:02:53.70 ] 桃白を含めて好きって程でもないけど嫌いじゃない。 ひと波乱あった今のEXCELVBAスレなら書き込むと荒れるかもしれないけど意外に有難がられるかもしれない
499 名前:デフォルトの名無しさん mailto:sage [2013/10/21(月) 00:45:14.12 ] 荒らし投稿した時点で既に論外
500 名前:デフォルトの名無しさん mailto:sage [2013/10/22(火) 18:20:53.28 ] 助けてください! Aセルの中に、東京都千代田区永田町1-7-1と入力されてます。 Aセルの中にある数字だけを抽出する事は可能でしょうか?(Bセルに1 Cセルに7 Dセル1) 可能であれば、マクロ組んでいただけませんか?
501 名前:デフォルトの名無しさん mailto:sage [2013/10/22(火) 19:36:40.31 ] 簡単過ぎて食指が動かないからやだ
502 名前:デフォルトの名無しさん mailto:sage [2013/10/22(火) 20:40:01.55 ] >>500 Range("B1")=1 Range("C1")=7 Range("D1")=1
503 名前:500 mailto:sage [2013/10/22(火) 20:40:34.13 ] では難しくしましょう。 Aセルの中の数字は、3つだけとは限りません。 「東京都千代田区大便町1-2-3-101」みたいに4つのこともありますし、 0個のときも、1個のときも、2個のときも、5個以上のこともあります。 さあ、お願いいたします。
504 名前:ピラフ [2013/10/22(火) 20:42:51.33 ] >>503 ピラフ挑戦してみようかな 4つ目の数字はEセルってことでいいの?
505 名前:デフォルトの名無しさん mailto:sage [2013/10/22(火) 20:52:19.98 ] >>484 478です お返事遅くなり申し訳ありません。 レスありがとうございます。 事故に遭い、レスをすることが出来ませんでした 皆様も車にはお気をつけて。
506 名前:デフォルトの名無しさん mailto:sage [2013/10/22(火) 21:02:14.04 ] >>503 それ、難易度の変化無いです。 つか>>500 本人とは思えんww
507 名前:デフォルトの名無しさん mailto:sage [2013/10/22(火) 21:19:32.45 ] >>503 ちょっと前にEXCEL VBAのスレで似た様な質問が挙がってたね。
508 名前:500 mailto:sage [2013/10/22(火) 21:43:36.77 ] みなさん、すみません。 住所の数字が増えた場合は、EセルFセルと右に移動できたらと思います。 よろしくお願いします。
509 名前:506 mailto:sage [2013/10/22(火) 21:51:51.73 ] でも実際、中小企業の事務所ってこういうレベルなんだよね。
510 名前:デフォルトの名無しさん [2013/10/22(火) 22:00:03.49 ] 住所のデータは分割しない方がいいよ 塊全部でひとつなのだから
511 名前:ピラフ [2013/10/22(火) 22:00:28.83 ] >>503 動きますかしら https://friendpaste.com/1IJsAt4r0u4ESjQuNgDXLE
512 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 03:14:08.82 ] わけがわからない なんのために番地をバラバラにするのか 漢数字には対応しなくていいのか 本当は処理したいのは住所じゃないと見た
513 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 04:45:42.24 ] そもそも、Aセルと言うのが俺には理解できないのだが 今だとA列にセルは100万個ぐらいあるんだがなぁ
514 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 08:19:36.09 ] >>513 マジで言ってんのか 馬鹿じゃないのか…
515 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 08:36:05.32 ] やっぱりまともなのはピラフちゃんだけだね ピラフちゃん好きだよ
516 名前:デフォルトの名無しさん [2013/10/23(水) 08:59:22.90 ] 住所の分割の必要性はまじでわからんな
517 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 10:48:12.66 ] アスペかよ
518 名前:デフォルトの名無しさん [2013/10/23(水) 11:37:44.47 ] 「住所から数字だけ抽出」をfor〜nextの自作で試してみた 25万件で1分55秒、50万件で3分33秒(シングルコア、画面更新・再計算停止) A列全ての1048576件はこれ以上と思うので試してない。
519 名前:500 mailto:sage [2013/10/23(水) 15:33:24.66 ] できたわ。 カス共サンクス
520 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 17:45:21.39 ] いえいえどういたしました
521 名前:ピラフ [2013/10/23(水) 19:59:57.25 ] >>519 なん・・・だと・・・
522 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 20:04:49.42 ] VBA初心者です。教えて下さい。数値で0があった時、その下のセルは斜線をつけるようにしたいです。また、0以外の数値の時は下のセルに薄いグレーの網掛けをしたいです。試してはいるもののうまくできません。よろしくお願いします。
523 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 20:16:17.55 ] >>522 ここのスレでもいいけど、 EXCELのVBAに関してはこっちの方が賑わっているから 返事も早いし色んな人の意見が聞けると思うよ。 Excel VBA 質問スレ Part32 toro.2ch.net/test/read.cgi/tech/1381151717/
524 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 20:20:30.14 ] >>522 とりあえずマクロの記録ってのを試してみよう。それが判らないってんでは話にならん
525 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 20:24:21.16 ] >>523 自演で賑わってるように見えるだけでしょ。 >>522 はクレクレ君のようだからそっちでいいと思うけど。 本スレはこっち Excel VBA 質問スレ Part32 toro.2ch.net/test/read.cgi/tech/1381151995/
526 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 20:33:33.23 ] 522です。ありがとうございます。教えていただいたスレに行って見ます。
527 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 20:39:08.22 ] >>525 行ってみましたが、何故本スレなのに10レスしか付いていないんでしょうか?
528 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 21:00:15.81 ] >>527 元々過疎スレだから。 コード作成依頼スレは自演してるからレス数が多くついてるだけ。 実際スレの中で自演してるって認めてるし。 toro.2ch.net/test/read.cgi/tech/1381151717/92 92 返信:デフォルトの名無しさん[sage] 投稿日:2013/10/17(木) 21:17:20.32 >>91 ここまで全部俺の自演でもいいから とっとと自分の立てた糞スレに帰りなさい。 羨ましそうに荒らしに来ない様に。 因みに過去スレが見れるのならテンプレを見れば こっちが本スレなのが分かると思うけど。 Excel VBA 質問スレ Part32 toro.2ch.net/test/read.cgi/tech/1381151995/
529 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 21:08:19.13 ] >>528 過去スレみて大体状況が分かりました。 何故レスが少ないのかも理解しました。 ありがとうございました。
530 名前:デフォルトの名無しさん mailto:sage [2013/10/23(水) 21:14:56.55 ] w
531 名前:デフォルトの名無しさん [2013/10/28(月) 08:01:59.06 ] ExcelのVBAからWebページを操作したいのですが (1)すでにあるページがひらいてるか調べる (2)もしひらいていたらそのページをアクティブにして前面に出し、そうでなければ新しく開く という手順を実行したいです。 苦労してるのは、InternetExplorerというブラウザを使っているのですが そのタブ機能があるのでブラウザは1個だけどその内部にタブが複数開いてるのを どうアクティブにするかで悩んでいます。 どうかよろしくお願いします
532 名前:デフォルトの名無しさん mailto:sage [2013/10/28(月) 16:28:16.09 ] 嫌です
533 名前:デフォルトの名無しさん [2013/10/28(月) 18:17:37.88 ] >>531 タブを複数開いていてもプロセスはタブごとに個別にあるよ
534 名前:531 [2013/10/28(月) 23:01:50.31 ] >>533 なるほどぉ。 ありがとぅ。 でも該当のやつをアクティブに、つまり前面に出すにはどうやるの?
535 名前:デフォルトの名無しさん mailto:sage [2013/10/28(月) 23:12:22.77 ] >>534 今どこまでできてんのか見せてみて
536 名前:デフォルトの名無しさん [2013/10/29(火) 00:08:08.87 ] >>534 しらね IEのオブジェクトをFor Eachでとれるんじゃね? それかOSレベルでのプロセス見つけてアクティベートとかできるんじゃね? しらねしらねー
537 名前:デフォルトの名無しさん [2013/11/02(土) 23:27:43.69 ] unlhaのAPI絡みの話ってここでしても良いんですか? ExcelのVBA上からなんですけど
538 名前:ピラフ [2013/11/02(土) 23:35:26.33 ] >>537 いんじゃない。書いちゃいなよ。
539 名前:デフォルトの名無しさん mailto:sage [2013/11/02(土) 23:47:49.12 ] 537です ソースは memopa.applest.net/d/112d26e7d487c3c35f に 内容は このマクロがあるフォルダにあるlzh圧縮ファイルを解凍し、出来たフォルダが xxxx なら それに " old" を付加しもう一つ xxx を作るというものです 解凍処理そのものは いろんなサイトで見てwなんとか出来たんですが、時たま(これが?なんですが)UNLHAが動作中ですというメッセージを 出して落ちてしまうことがあります。 んでUNLHAのドキュメントでは UnlhaGetRunningとかで動作確認をするとか。これをVBA上で実現する方法をしりたいのですが。 ↑に貼ったソースでは該当部分はコメント化してあります。 'Public Declare Function UnlhaGetRunning Lib "UNLHA32.DLL" Alias "Unlha" () As Boolean 'If UnlhaGetRunning() Then ' MsgBox "UNLHAが現在動作中 一旦このブックを閉じて再度実行してください" ' Exit Sub 'End If の部分です
540 名前:デフォルトの名無しさん mailto:sage [2013/11/03(日) 02:02:16.59 ] >>539 UNLHA32.DLL は複数同時実行に対応していないんだから、 調子に乗って連続で実行してる時とかに間に合わなくて普通にExitしてるんだろ 適当にループでもさせとけば?
541 名前:デフォルトの名無しさん mailto:sage [2013/11/03(日) 08:18:57.49 ] >>540 レスありがとです。unlha32.dllはスレッドセーフではないっていうことですよね。 で、その「適当にループさせる」ってのは具体的にはどういうことなんでしょうか
542 名前:デフォルトの名無しさん mailto:sage [2013/11/03(日) 08:37:12.78 ] >>539 使ってないからよくわからんが引数とか戻り値の型とか違うんだけど? www31.ocn.ne.jp/~heropa/vb05.htm
543 名前:デフォルトの名無しさん mailto:sage [2013/11/03(日) 11:51:58.89 ] >>542 api定義の部分はさすがに同じだと思うのですが… 後、引数については、、取り敢えずあとで見返してみます^^; 自分のソースの 'UNLHA32.DLL呼出API Public Declare Function UNLHA Lib "UNLHA32.DLL" Alias "Unlha" _ (ByVal hwnd As Long, ByVal szCmdLine As String, _ ByVal Lpstr As String, ByVal wsize As Long) As Long Dim lngRet As Long www31.ocn.ne.jp/~heropa/vb05.htm Declare Function Unlha Lib "UnLHA32.DLL" _ (ByVal hwnd As Long, _ ByVal szCmdLine As String, _ ByVal szOutput As String, _ ByVal dwSize As Long) AS Long Dim lngResult As Long
544 名前:デフォルトの名無しさん mailto:sage [2013/11/03(日) 12:06:57.35 ] >>543 はあ? >>539 は自分のソースじゃないのか? 悪いけど、抜けるわ。
545 名前:デフォルトの名無しさん mailto:sage [2013/11/03(日) 16:10:28.85 ] >>541 俺は>>540 じゃないけど スレッドセーフって意味わかってる? 今までの情報ではunlha32.dllがスレッドセーフかどうかは判断できない 適当にループさせるってのは、何も考えなければ 実行中の状態が実行中で無くなるまで、ひたすら実行中かどうかをチェックするってことだ 極端に言えばこんな感じ Do While UnlhaGetRunning() Loop 実際には時間切れとかシステムの占有率とか考えないとダメかもしれんが
546 名前:デフォルトの名無しさん mailto:sage [2013/11/03(日) 17:07:50.83 ] >>545 情報不足ですいません Unlhaがスレッドセーフでないってのは、unlha32.dllの作者である人がそのAPI 説明ファイルの冒頭で UNLHA32.DLL はスレッド・セーフではありません。(^^;) 従って, 複数スレッドからの同時使用は行えませんので 注意してください。 と書いているんで、そうなのですかということで。
547 名前:デフォルトの名無しさん mailto:sage [2013/11/03(日) 18:21:28.23 ] >>546 作者がそう言ってるのならそうでしょう そもそもVBAはシングルスレッド前提の言語なんで、VBAで複数スレッドから同時に使用するのは大変ですが
548 名前:537 mailto:sage [2013/11/04(月) 21:38:21.65 ] 宣言部分が間違っていたみたいで Public Declare Function UnlhaGetRunning Lib "UNLHA32.DLL" Alias "Unlha" () As Boolean ↓ Public Declare Function UnlhaGetRunning Lib "UNLHA32.DLL" () As Boolean で If UnlhaGetRunning() = True Then MsgBox "UNLHA動作中" Exit Sub Else MsgBox "test **** UnlhaGetRunningの動作確認 UNLHAはFALSE ****" End If ではtest **** UnlhaGetRunningの動作確認 UNLHAはFALSE ****が表示され、以下の処理も正常に終了 これで正しいのかどうか不安には思いながらも取り敢えずお終い
549 名前:デフォルトの名無しさん mailto:sage [2013/11/22(金) 15:38:59.33 ] VBAからZip32jを呼び出してファイルをZIP形式で圧縮しているのですが、 ファイル名が「@@file.xls」のようにアットマークで始まるファイルが 圧縮できません。 strCommand = "-u ""file.zip"" ""@@file.xls""" lngSize = Len(str) RC = Zip(hwnd, strCommand, str, lngSize) ざっくり書くとこんな感じでZip32jに渡しているのですが、 こういう場合はZip32jにどういう風にファイル名を渡せば 良いのでしょうか。
550 名前:デフォルトの名無しさん mailto:sage [2013/11/22(金) 18:15:51.32 ] えすけーぷしーけんす?
551 名前:デフォルトの名無しさん mailto:sage [2013/11/22(金) 18:31:02.89 ] ふるぱす?
552 名前:デフォルトの名無しさん mailto:sage [2013/11/22(金) 18:31:42.41 ] ティンコ?
553 名前:デフォルトの名無しさん mailto:sage [2013/11/22(金) 20:35:05.46 ] マンコ?
554 名前:デフォルトの名無しさん mailto:sage [2013/11/22(金) 20:39:15.37 ] (´・ω・`)b
555 名前:555 mailto:555 [2013/11/22(金) 20:40:13.16 ] 555げっち(´・ω・`)b
556 名前:デフォルトの名無しさん [2013/11/25(月) 17:34:43.29 ] 質問です。 Set res = Rows(1).Find(What:="2013") これでオブジェクトが必要です。とエラーが出てしまうのですが、原因わかる方いますか? 検索結果がない可能性があるので、この後resのNothing判定をする予定です。
557 名前:デフォルトの名無しさん [2013/11/25(月) 17:45:00.48 ] >>556 この1行ならエラー出なかったょ 他でエラー発生してるんじゃない?
558 名前:デフォルトの名無しさん mailto:sage [2013/11/25(月) 17:56:44.97 ] >>556 Findの罠だな これで動くこともあるからタチが悪い 面倒でも検索条件を省略せずにきちんと書いてみ
559 名前:デフォルトの名無しさん [2013/11/25(月) 17:57:01.51 ] >>556 Dim res の記述はどうなってる? 'Dim res As Integer 'オブジェクトが必要です エラー 'Dim res As Single 'オブジェクトが必要です エラー 'Dim res As Double 'オブジェクトが必要です エラー 'Dim res As String 'オブジェクトが必要です エラー を再現した。 By 557
560 名前:デフォルトの名無しさん [2013/11/25(月) 18:04:14.58 ] 実際のコードです。エラーのあとデバッグを選択するとp.findの行で止まるので間違いないと思います。 Dim res As Variant ←これはいれてもいれなくてもエラーになります。 以前自分が作ったコードでは、同じような記述で動いていたのでこれでいいのかと。。。 省略せずに書くというのは、どこまで書けばいいのでしょうか? p = Rows(1) o = Year(DateAdd("m", mo, Cells(r, 2))) Dim res As Variant Set res = p.Find(What:="2013")
561 名前:デフォルトの名無しさん mailto:sage [2013/11/25(月) 18:05:49.51 ] set p = rows(1)
562 名前:デフォルトの名無しさん [2013/11/25(月) 18:08:29.33 ] ありがとうございます。 解決しました・・・・ほんとバカで申し訳ない。
563 名前:デフォルトの名無しさん mailto:sage [2013/11/25(月) 18:55:09.63 ] ズコー
564 名前:デフォルトの名無しさん mailto:sage [2013/11/26(火) 12:53:02.32 ] プロシジャが operation1 operation2 operation3 とあって通常だったらoperation1からoperation2,opration3を 一連の流れで実行するのがあります。 operation3にはoperation1でGetOpenFilenameで得たフォルダ名を引数にして call opration3(フォルダ名) と書いてるんですが、このoperation3だけを単独で実行したい場合 どうします?勿論フォルダ名をどうにかして引数に与えるなりしないといけないん ですが。
565 名前:564 mailto:sage [2013/11/26(火) 15:46:06.67 ] ope3_tandokuプロシジャを作り、そこでフォルダを与え、このプロシジャ中で operation3(フォルダ) で、このope3_tandokuをボタンで起動することにしました
566 名前:デフォルトの名無しさん mailto:sage [2013/11/26(火) 19:14:50.03 ] よくできました
567 名前:デフォルトの名無しさん mailto:sage [2013/11/27(水) 19:59:41.41 ] call operation3(フォルダの取得関数())じゃないのか、普通は
568 名前:デフォルトの名無しさん mailto:sage [2013/12/10(火) 21:24:24.39 ] 64ビット版Excel VBAでmscomctl.ocxのListViewが使えなくて困っています。 ListBox以外で、64ビット版対応方法を知っている人はいませんか?
569 名前:デフォルトの名無しさん mailto:sage [2013/12/29(日) 13:03:57.51 ] ググれば出てくるじゃん
570 名前:デフォルトの名無しさん [2013/12/29(日) 20:03:14.90 ] マクロでリストを作ろうと思い、試しに簡易版のマクロを組みました。 しかし、リストで参照してしるところが相対参照したいのですが、Formula1:="=$A$25:$D$25をどう変更したらいいでしょうか? ご教示ください。 Sub Macro1() ' ' Macro1 Macro Range("E24").Select ActiveCell.Offset(1, 0).Select Do With Selection.Validation .Delete .Add Type:=xlValidateList, AlertStyle:=xlValidAlertStop, Operator:= _ xlBetween, Formula1:="=$A$25:$D$25" .IgnoreBlank = True .InCellDropdown = True .InputTitle = "" .ErrorTitle = "" .InputMessage = "" .ErrorMessage = "" .IMEMode = xlIMEModeNoControl .ShowInput = True .ShowError = True End With ActiveCell.Offset(25, 0).Select Loop Until ActiveCell.Row = 100 End Sub
571 名前:デフォルトの名無しさん mailto:sage [2013/12/29(日) 20:07:55.37 ] すいません 下げわすれてました。
572 名前:デフォルトの名無しさん mailto:sage [2013/12/29(日) 23:10:51.30 ] 全くソース読む気も無いが、$A$25:$D$25は相対指定じゃない事はわかるぞ A25:D25でいいんじゃないかね
573 名前:デフォルトの名無しさん mailto:sage [2013/12/30(月) 07:32:19.42 ] >>572 そこは絶対参照のままでもいいんじゃないの? やりたいことが、漏れなく書かれてるわけじゃないから違ってるかも知れないが エスパーすると、たぶんこういうことがしたいのだと思われ >>570 Sub Macro1() Dim r As Long For r = 25 To 75 Step 25 Cells(r, 5).Validation.Delete Cells(r, 5).Validation.Add xlValidateList, xlValidAlertStop, xlBetween, _ "=" & Cells(r, 1).Resize(1, 4).Address Next r End Sub 因みに相対参照にするなら、.Address → .Address(0, 0) しかし、自分の知ってる事というか自分が思い描いてることは 相手も把握している前提で話をするおバカさんって厄介だよね ここはVBAの質問に答えるスレのはずなのに、VBAレベル的には初心者でも回答できるものばかりだが 正しい日本語で齟齬無く要望を伝える能力に欠けた奴の意図をエスパー的に酌み取る事の方ばかり 高レベルの能力が必要とされている気がする まぁ俺もエスパーは本分じゃないんで、上記のコードも要望通りじゃないかもしれないけどw
574 名前:18 mailto:sage [2013/12/30(月) 09:44:13.82 ] >>573 > .Address(0, 0) とか書く奴に偉そうなこと言われても...
575 名前:デフォルトの名無しさん [2013/12/30(月) 09:44:24.16 ] 質問がある。 その質問内容についてはすべてエスパーしてくれ。 で回答は具体的で詳細に。 ではよろしく頼む。
576 名前:デフォルトの名無しさん mailto:sage [2013/12/30(月) 10:24:26.23 ] >>574 何勘違いしてるの?
577 名前:18 mailto:sage [2013/12/30(月) 12:38:10.77 ] >>576 >>574 の指摘内容が理解できてないの? (w
578 名前:デフォルトの名無しさん mailto:sage [2013/12/30(月) 12:38:38.33 ] すいません。 事の発端の>>570 です。 自分のやりたいことを詳細に書き込まず、予想して補完してもらうような、質問をして申し訳ありませんでした。 >>572 さん>>573 さんありがとうございました。
579 名前:デフォルトの名無しさん mailto:sage [2013/12/31(火) 10:44:06.16 ] >>577 まぁ、、、がんばれw
580 名前:18 mailto:sage [2013/12/31(火) 11:12:02.61 ] >>579 理解できてないのか... て言うか、普通インテリセンスが効くから 0 なんて書くわけないと思うんだが。
581 名前:デフォルトの名無しさん mailto:sage [2013/12/31(火) 13:03:01.75 ] もしかしてAddress(False, False)って書け、なんてレベルの話? しかし、Addressの第一、第二引数は、規定値がTrueとはいえ、Boolean型ではなくVariant型で それ故にインテリセンスも効かないし、そういうコードの明示性で言うなら、25や75を定数化しろって方が先な上に こういう金を貰えるわけでもない場では明示性や読解性を犠牲にしてでも簡略化するのは常套手段なので Addressの第一、第二引数には効かないインテリセンスがどうこう言ってることからしても、 0ではなく、Falseや相対参照を意味する定数を定義してそれを使えなんて単純な話じゃないよね? いったい、どう書くのが正しいと言いたいのだろう?
582 名前:デフォルトの名無しさん mailto:sage [2013/12/31(火) 20:31:10.76 ] あんまり虐めるな
583 名前:デフォルトの名無しさん mailto:sage [2013/12/31(火) 20:45:45.07 ] エクセルは表計算が少しできます。マクロとかは知りません。 VBAをマスターしたく本屋へ行きましたがたくさんあり悩みました。 「10日間でマスター・・・」みたいなのがありましたが初心者でも大丈夫で しょうか?そもそも10日間でマスターできるほど簡単?とは思えないのですが 初歩ですかね?
584 名前:デフォルトの名無しさん [2013/12/31(火) 21:05:06.28 ] >>581 は虐めてはいないだろ >>574 が井の中の蛙なだけ 小山の大将が、飛行機から見下された
585 名前:デフォルトの名無しさん [2013/12/31(火) 21:19:31.20 ] >>583 初心者の入門用には、その程度から始めるのが良いかも。 ただ、同時に分厚いVBAの辞書みたいなのも買う事を勧める。 少しできるようになったら、疑問が出るだろうから本を買足すのも良いだろう。 また、「参照設定」での機能を説明している本は少ないので、 そこら辺はネット併用で情報収集して行けばよいと思う。
586 名前:デフォルトの名無しさん mailto:sage [2013/12/31(火) 21:41:38.76 ] >>583 そもそも何がしたいかなんて人によって違う デカい本屋で一日潰して立ち読みでもしてみて、一番自分がやりたいことが 分かるように書かれてる本を買え ただ関数・メソッドの癖なんかは一々細かく覚えてられんので、リファレンス本は持っておけ
587 名前:583 [2014/01/01(水) 10:02:50.80 ] 皆さん、ご丁寧に回答頂きありがとうございます。
588 名前:デフォルトの名無しさん [2014/01/01(水) 10:42:09.00 ] >>585 「参照設定」を話題にするということは、これはものすごく便利なものということですね? IEを操作するという本で見たことだけはあるけど これは何のために使い、何が便利なのですか?
589 名前:デフォルトの名無しさん mailto:sage [2014/01/01(水) 16:04:34.73 ] >>588 キーワードが分かってるなら少しはggks 便利かどうかは自分で判断しろ
590 名前:588 [2014/01/04(土) 10:07:28.34 ] >>589 そりゃないよかあちゃん。 参照設定とはなにかどなたかおしえてくださいませんでしょうか?
591 名前:デフォルトの名無しさん mailto:sage [2014/01/04(土) 10:44:10.13 ] >>590 アプリケーションを「インストールする」みたいなそれ単体では無意味な言葉w
592 名前:588 [2014/01/04(土) 10:46:02.02 ] >>591 レスありがとうございます。 ん、どういうことでしょう? 言葉の意味がよくわからないのですが・・・
593 名前:デフォルトの名無しさん mailto:sage [2014/01/04(土) 12:43:00.21 ] アプリケーションをインストールするとは、広義では、アプリケーションを実際に使える状態にすることをいう レジストリ登録は必須ではない
594 名前:デフォルトの名無しさん mailto:sage [2014/01/04(土) 12:48:49.63 ] USBメモリに入れて持ち運べるアプリケーションも それを入れたUSBメモリを接続すること自体がインストール
595 名前:588 [2014/01/04(土) 13:10:34.76 ] ?
596 名前:デフォルトの名無しさん mailto:sage [2014/01/04(土) 15:59:41.71 ] SDDのインストロールをファイルしてディスクトップのコピペをオーエスするんだよ
597 名前:デフォルトの名無しさん mailto:sage [2014/01/07(火) 16:30:54.74 ] >>588 別に詳しいこと知らなくても使い方だけ知ってればそれでいいじゃん 俺も知らないけど特に困ってないよ。 とりあえずエクセルの標準的な設定では使えない機能が ライブラリっていう形で用意されてて、 それを参照するように設定することでライブラリの機能が利用できるようになるってことらしいよ。 参照設定の内容はブックごとに保存されるから別のPCにコピーしても同じように動く。 ただし、用意されてるライブラリはエクセルのバージョンごとに違ってるから コピー先のマシンにインストールされてるエクセルのバージョンによっては エラーが出て動かない場合もある(らしい)。 あと、参照設定しないでライブラリの機能を利用することも出来るけど、 その時はインテリセンスが働かないからコード書くときにちょっと面倒だったりする。 一例としてFileSystemObjectを使うときには Microsoft Scripting Runtimeっていうライブラリを参照設定しておくと Dim fso As New FileSystemObject って宣言するだけでFileSystemObjectが使えるけど、 参照設定してないと Dim fso As Object Set fso = CreateObject("Scripting.FileSystemObject") みたいに書かないといけない。 そして、参照設定していればコード中でインテリセンスが働くから fso.とタイプしたらその後に続くメソッドとかが表示されるけど 参照設定してないとそれが出てこない。 大体こんな程度しか知らないけど、今のところ特に困ってない。
598 名前:デフォルトの名無しさん mailto:sage [2014/01/07(火) 17:40:10.13 ] >>588 プログラミングの学習は、いくら言葉を覚えて知識だけ詰め込んだって全然ダメだ。 最初はサンプルの丸写しでもいいから、とにかく手を動かせ。
599 名前:デフォルトの名無しさん mailto:sage [2014/01/07(火) 19:49:40.93 ] > ただし、用意されてるライブラリはエクセルのバージョンごとに違ってるから エクセルではなく大抵はOSやIEな よく使用されるのは、Excelに付属するライブラリより、OSやIE付属のライブラリだから 例に挙げてるFSOも、Excel付属ではなく、OSに付属するIEに付属するWSHに付属するライブラリだから
600 名前:597 mailto:sage [2014/01/07(火) 20:31:40.45 ] >>599 そうなんですか、それは知りませんでした。 (この辺が良く知らないと言う由縁) 教えていただきありがとうございました。
601 名前:デフォルトの名無しさん mailto:sage [2014/01/08(水) 04:38:24.94 ] FSOはもともとOS付属ではなかったが 参照設定は、ある共通ルールに従って作られたプログラムを使用するために使うもの 別に何かの付属のライブラリじゃなくても良いんだぞ
602 名前:デフォルトの名無しさん mailto:sage [2014/01/08(水) 05:17:40.58 ] FSOが付属するようになったのはWin98SEからだっけ? 確かWin95やWin98だと、IEのバージョンアップするか、WSHの単体パッケージ入れる必要があったような
603 名前:デフォルトの名無しさん mailto:sage [2014/02/07(金) 11:57:08.30 ] intにキャストすると小数部四捨五入するのやめれ。
604 名前:デフォルトの名無しさん mailto:sage [2014/02/07(金) 13:53:01.88 ] >>603 暗黙の変換に頼る方が悪い 適切な関数なり数式なりで処理しろ
605 名前:デフォルトの名無しさん mailto:sage [2014/02/07(金) 14:09:14.80 ] ところがclng()より速いのがVBA
606 名前:デフォルトの名無しさん mailto:sage [2014/02/07(金) 23:57:24.63 ] >>603 四捨五入じゃないんだけどな それ以前にintにキャストってそれホントにVBAの話か
607 名前:デフォルトの名無しさん mailto:sage [2014/02/08(土) 00:51:47.10 ] CType関数は小数点以下丸めることがあるから、小数切り捨てたい場合は使ったらあかんのね。
608 名前:デフォルトの名無しさん mailto:sage [2014/02/08(土) 01:19:57.82 ] >>607 切り捨ては丸めの方法の一つだから、その日本語はおかしい
609 名前:デフォルトの名無しさん [2014/02/13(木) 14:00:02.20 ] テキストボックスに文字を設定する時に 通常はチェンジイベントで設定された文字を処理するように書いてますが とあるタイミングではチェンジイベントを実行したくないのです その、とあるタイミングの前に、テキストボックスのEnabledプロパティをFalseにすれば チェンジイベントが発生しないのかと思ったら発生しますね そうなると、とあるタイミングの前に、グローバル変数を設定して イベントの中でその変数を見て抜けるようなベタな方法しかないですか?
610 名前:デフォルトの名無しさん mailto:sage [2014/02/13(木) 14:12:23.89 ] >>609 そこで一時的に全部のイベントを殺してもいいのならEnableEvents 止めたいのがテキストボックスのチェンジイベントだけなら自前でフラグ変数を用意しかない
611 名前:デフォルトの名無しさん [2014/02/13(木) 14:24:24.41 ] >>610 VBAにはそんなのがあるのですか、良いですね VB6のスレが無かったので、同じだろうと思ってここでお聞きしましたがVB6にはないようでした ありがとうございました
612 名前:デフォルトの名無しさん mailto:sage [2014/02/13(木) 14:56:01.33 ] EnabledがFalseでイベント発生したっけ? イベントが発生してから無効にしてるんじゃないかと言う気がするが
613 名前:デフォルトの名無しさん [2014/02/14(金) 12:48:25.84 ] 説明が足りませんでした Enabled=Falseでユーザー操作はできなくなりますが コードからは操作できて、その時にイベントが発生してしまいます
614 名前:デフォルトの名無しさん mailto:sage [2014/02/14(金) 13:24:45.38 ] VBAならAfterUpdate使え それ以外なら知らん
615 名前:デフォルトの名無しさん mailto:sage [2014/02/15(土) 20:19:21.38 ] Enabled=Falseの時のイベント発生を除外したいなら、 イベントハンドラでEnabledの値を確認すれば解決。
616 名前:デフォルトの名無しさん [2014/02/16(日) 07:35:43.11 ] なるほど、本来の使い方ではないけど、それでいいわけですよね 対象のコントロールが少ないならグローバル変数を用意するよりスマートだし
617 名前:デフォルトの名無しさん [2014/02/16(日) 21:56:15.35 ] スマートは大事
618 名前:デフォルトの名無しさん mailto:sage [2014/03/12(水) 02:35:55.66 ID:oH1Ugruw] ID発行記念カキコ
619 名前:デフォルトの名無しさん mailto:sage [2014/03/15(土) 07:03:26.55 ID:FLjN0SBh] 実現の可否が分からないため、質問させて下さい。 Excel VBAでShell関数を使い、Powershellを呼び出し、その出力結果をtxtに出力して取り込んでいます。 Powershellを走らせて待っている間、Powershellの処理に時間がかかる場合に「(応答なし)」が表示されます。 待っていると動いてくれるので「(応答なし)」は表示させたくないのですが、DoEventsを使ってもだめでした。 「(応答なし)」を表示させない方法はあるのでしょうか。
620 名前:デフォルトの名無しさん mailto:sage [2014/03/15(土) 07:37:44.08 ID:kKPzvMNA] 「Powershellを走らせて待っている間」について詳しく
621 名前:デフォルトの名無しさん mailto:sage [2014/03/15(土) 07:47:18.40 ID:IpiW3W82] ついでに、その応答なしってどこに表示されるかも
622 名前:デフォルトの名無しさん mailto:sage [2014/03/15(土) 10:15:49.53 ID:FLjN0SBh] >>620 >>621 powershellで「compare-object」という比較のコマンドを実行しています。 比較するデータと結果の差分が多いと出力に時間がかかり、作成したユーザフォームの左上にあるcaptionに「(応答なし)」と表示されてきます (10秒位経っただけで表示されてしまう印象)。 その「(応答なし)」を表示させない方法があるのかどうか、知りたいと考えています。
623 名前:622 mailto:sage [2014/03/15(土) 10:19:01.52 ID:FLjN0SBh] 処理の流れとしては、 ユーザフォームでファイルを選択させて、 もろもろのオプションを指定した上で、 実行してpowershellを呼び出してcompare-objectで比較して出力、 という内容になります。
624 名前:デフォルトの名無しさん mailto:sage [2014/03/15(土) 10:33:33.89 ID:bmQ5jObQ] VBA側のCaptionに表示させたくない文字列の内容が分かってるなら、 単に条件分岐させて消すなりなんなりすればいいじゃん
625 名前:622 mailto:sage [2014/03/15(土) 11:08:40.69 ID:FLjN0SBh] >>624 すいません、正式名称が何というのか分かっていなかったのですが、「タイトルバー」ですかね、、、 Captionの右側に「(応答なし)」が表示されてきたので、622の箇所ではCaptionと書いてしまっています。 622の質問の段階で、Captionで意味が通じているようであれば、 条件分岐をさせて「(応答なし)」を出さない方法がよく分かっていないです。
626 名前:デフォルトの名無しさん mailto:sage [2014/03/15(土) 11:52:35.81 ID:kKPzvMNA] 『待っている間』について詳しく
627 名前:622 mailto:sage [2014/03/15(土) 14:12:17.82 ID:FLjN0SBh] >>626 コードの必要な箇所を抜き出すと以下になります。 ====================== Public Const PROCESS_ALL_ACCESS As Long = &H1F0FFF Public Const INFINITE As Long = &HFFFF Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, _ ByVal dwMilliseconds As Long) As Long Declare Function OpenProcess Lib "kernel32" (ByVal dwDesiredAccess As Long, _ ByVal bInheritHandle As Long, _ ByVal dwProcessId As Long) As Long Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long If 〜 Then Dim TaskId As Long Dim hProc As Long DoEvents TaskId = Shell("powershell " & Chr(34) & "& { " & 〜 & "}" & Chr(34), vbMinimizedNoFocus) hProc = OpenProcess(PROCESS_ALL_ACCESS, 0, TaskId) If hProc <> 0 Then Call WaitForSingleObject(hProc, INFINITE) CloseHandle hProc End If End If ====================== 実のところ、shell関数の所で止まっていると思い込んでいたのですが、確認したところだと、powershellというよりは後続の同期処理、「Call WaitForSingleObject(hProc, INFINITE)」のところで起きているようでした。 おそらくこの部分を変えてやればうまくいくと思うのですが、しかしどうすればいいのか、分からない状況です。
628 名前:デフォルトの名無しさん mailto:sage [2014/03/15(土) 16:15:36.48 ID:3ah5yf0J] >>627 同期処理用のAPIではどうしても応答なしになってしまう Powershellのスクリプトの最後で、処理の完了を通知するぐらいしか思いつかない たとえばテンポラリファイルを使うとか原始的な方法で
629 名前:デフォルトの名無しさん mailto:sage [2014/03/15(土) 16:37:06.66 ID:IpiW3W82] >>627 > WaitForSingleObject 一番最後の引数に 1000 ぐらいを指摘して、1秒毎にポーリングすればいい。 タイムアウトかプロセスが終了したのかは戻り値を見ればわかる。
630 名前:デフォルトの名無しさん mailto:sage [2014/03/15(土) 16:42:00.26 ID:bmQ5jObQ] >>628 Function findMyBook($bookname) $books = [System.Runtime.InteropServices.Marshal]::GetActiveObject("Excel.Application") foreach ($mybook in $books.WorkBooks){ if ($books.Name -eq $bookname){ return $mybook } } 実行するVBAのブック名が固定されるんなら、PS側の必要な処理が終わった後に PS側でそのブック名見つけてやればいいんじゃないかね多分
631 名前:622 mailto:sage [2014/03/15(土) 22:02:16.82 ID:FLjN0SBh] >>629 VBAを以下のように修正し、応答なしが出なくなったことを確認しました。 ====== (前) If hProc <> 0 Then Call WaitForSingleObject(hProc, INFINITE) CloseHandle hProc End If ====== (後) Dim RC As Long If hProc <> 0 Then Do RC = WaitForSingleObject(hProc, 1000) DoEvents Loop While (RC = &H102) If RC <> 0 Then Exit Sub End If CloseHandle hProc End If ====== >>630 VBAの方でうまくいったのでpowershellの方は試していませんが、別の機会に試してみます。 皆様、ご協力ありがとうございました。
632 名前:デフォルトの名無しさん mailto:sage [2014/03/15(土) 22:29:46.48 ID:IpiW3W82] >>631 > If RC <> 0 Then > Exit Sub > End If > CloseHandle hProc RC <> 0 の時もハンドルクローズしないとリークするよ。
633 名前:デフォルトの名無しさん mailto:sage [2014/03/16(日) 09:30:39.93 ID:cyT7e+/z] >>632 ご指摘助かります。 入れておきます。
634 名前:デフォルトの名無しさん mailto:sage [2014/03/30(日) 01:09:57.92 ID:HkRxLSsC] 配列(A,B,C,D) 配列(123,456,789) これを下記のようにDebug.Printしたいのですが、コードをご教授ください。お願いします。 A123 B123 C456 D456 E789 F789
635 名前:ピラフ [2014/03/30(日) 02:33:17.39 ID:aRmbpBvo] >>634 ピラフが教えてあげちゃう。 Dim A A = Array("A", "B", "C", "D", "E", "F") Dim B B = Array("123", "456", "789") Dim I I = 0 Dim E For Each E In B Debug.Print A(I) & E Debug.Print A(I + 1) & E I = I + 1 Next
636 名前:デフォルトの名無しさん mailto:sage [2014/03/30(日) 03:21:41.62 ID:HkRxLSsC] >>635 ピラフ様 あなたが私を救って下さいました。ありがとう。(心臓)
637 名前:デフォルトの名無しさん mailto:sage [2014/03/30(日) 07:21:17.99 ID:5cM6x3wc] 二人ともよく見ろ できてないじゃん タオパイの自演か?
638 名前:デフォルトの名無しさん mailto:sage [2014/03/31(月) 01:17:01.74 ID:+/Q0rb5y] Debug.Print A(I + I) & E Debug.Print A(I + I + 1) & E
639 名前:デフォルトの名無しさん [2014/03/31(月) 13:20:56.18 ID:dIVDD8y4] 天津飯が好きです@22歳OL
640 名前:デフォルトの名無しさん mailto:sage [2014/03/31(月) 19:39:21.01 ID:+xOJ5BKc] >>638 なんじゃそりゃw ふつーは I = I + 2 だろ
641 名前:桃白白 ◆9Jro6YFwm650 [2014/03/31(月) 21:27:38.02 ID:N162Y8AS] >>639 桃白白のことは?好き?
642 名前:デフォルトの名無しさん mailto:sage [2014/03/31(月) 21:47:20.15 ID:DtbGifhU] 桃(も)白(ちろ)白(ん)
643 名前:デフォルトの名無しさん [2014/04/01(火) 23:08:43.56 ID:iMQ7tFIo] Excel VBAで、シートのOELobjectsとしてファイルを追加しましたが、 そのファイルをまたファイルとして出力する方法がよくわかりません。 ご教示いただけないでしょうか。 一時的なバックアップとしてファイルをシート上に保管して、問題があったらそこからファイルを復元しようとしてます。
644 名前:デフォルトの名無しさん mailto:sage [2014/04/17(木) 08:27:13.26 ID:112XWAfL] ここは貼ってもいいんでしょうか? 作ったものが全く思い通りに動かず悩んでます。 初心者なので別スレがあるのであれば教えていただけますと移動いたします。
645 名前:デフォルトの名無しさん mailto:sage [2014/04/17(木) 09:14:36.93 ID:jEbNeAxo] 短いのならここに直接貼ってもいいよ 長いのはコード貼るサイト使った方がいいと思
646 名前:デフォルトの名無しさん mailto:sage [2014/04/17(木) 10:04:40.69 ID:112XWAfL] ありがとうございます。技術が無いので無駄に長くなってしまっています。
647 名前:デフォルトの名無しさん mailto:sage [2014/04/17(木) 10:12:07.35 ID:jEbNeAxo] とりあえず、コード貼れるサイト https://friendpaste.com/ 選択肢にVBAがないからVB.netでも選んどいて
648 名前:デフォルトの名無しさん mailto:sage [2014/04/20(日) 23:00:50.17 ID:s+35q5Om] >>644 コードまだー? 俺も初心者だから他人の書いたコードを参考にしたいんだよー
649 名前:デフォルトの名無しさん mailto:sage [2014/04/21(月) 07:31:38.50 ID:4zlYEuTE] 自己解決しました どうも
650 名前:デフォルトの名無しさん mailto:sage [2014/04/23(水) 20:07:42.26 ID:xveRB+Bl] ExcelのA1〜F1に任意で入れた数字を降順で並べたいんだけどよくわからん… バブルソートさせるのはわかるが、表から数値を持ってくるにはどうしたらいいんですか?
651 名前:デフォルトの名無しさん mailto:sage [2014/04/23(水) 20:44:27.34 ID:ZM+hJQpr] >>650 a = Range("A1:F1")
652 名前:デフォルトの名無しさん mailto:sage [2014/04/24(木) 00:53:35.48 ID:m6J4LtNe] >>651 sub sort() Dim a As Integer Dim i As Integer Dim j As Integer Dim min As Integer a = Range(A1:F1) Do While j < a - 1 i = j + 1 Do While i < a End Sub よくわからん
653 名前:デフォルトの名無しさん mailto:sage [2014/04/24(木) 01:40:46.12 ID:nXU9pvpI] >>652 aは配列 Rangeは初心者にはおすすめしない Dim a() As Integer Dim i As Integer For i = 1 To 6 a(i) = Cells(1, i) Next 宿題は自分でやれ
654 名前:デフォルトの名無しさん mailto:sage [2014/04/24(木) 18:08:41.31 ID:NeL4TUu8] デフォルトプロパティ省略するのやめた方が良いぞ
655 名前:デフォルトの名無しさん [2014/04/24(木) 18:30:46.52 ID:ZALVHb/C] >>654 それはなぜですか?
656 名前:デフォルトの名無しさん mailto:sage [2014/04/24(木) 19:43:11.79 ID:nXU9pvpI] 左辺がVariantじゃないから大丈夫
657 名前:デフォルトの名無しさん mailto:sage [2014/04/24(木) 20:07:59.57 ID:mnsZs1hI] 今時学校でVBAを教えるところがあるのか
658 名前:デフォルトの名無しさん [2014/04/29(火) 17:43:11.79 ID:cd9z2Wuk] PDFで問題となっているものを、マクロを使って以下のように以下のようにできますでしょうか? もし、可能ならばご教示ください。 1、PDF上の問題記号を選択すると解答選択肢が出てくる。(リストボックスのように) 2、その中から解答を選択できる。 3、最後に正答率、間違ったところの答え、間違ったところの根拠表示
659 名前:sage [2014/04/29(火) 17:44:53.56 ID:cd9z2Wuk] すいません。上げてしまいました。
660 名前:デフォルトの名無しさん mailto:sage [2014/04/29(火) 17:55:04.83 ID:KFswrGoL] すいません。
661 名前:デフォルトの名無しさん mailto:sage [2014/04/29(火) 17:59:31.75 ID:AVYTmVui] >>658 とりあえずPDFのサンプルをどっかにアップしてください
662 名前:デフォルトの名無しさん mailto:sage [2014/04/29(火) 18:09:22.14 ID:KFswrGoL] www.pref.kochi.lg.jp/soshiki/310601/h24itijisinnsamondaitokaitou.html の一番上にある教職・一般教養 [PDFファイル/1.93MB】です。 よろしくお願いします。
663 名前:デフォルトの名無しさん mailto:sage [2014/04/29(火) 18:21:18.11 ID:/qylVqTc] >>658 そのPDFの内容のうち、どこが問題記号でどこが解凍選択肢か、正解はどれか そう言った情報が機械的に判断できる必要があるんだが、それは可能なのか?
664 名前:デフォルトの名無しさん mailto:sage [2014/04/29(火) 18:25:24.29 ID:8Pfgcz1/] >>658 ttp://pdf-file.nnn2.com ここでも嫁
665 名前:デフォルトの名無しさん mailto:sage [2014/04/29(火) 18:35:52.24 ID:hNJPTToz] >>663 そうですね。確かに正解と回答を参照することが頭から抜けていました。正解は正解のPDFを元に手打ちで、Excelに打ち込もうかと思うのですが、良い方法はありますでしょうか?
666 名前:デフォルトの名無しさん mailto:sage [2014/04/29(火) 18:37:58.44 ID:hNJPTToz] >>663 >>>658 >そのPDFの内容のうち、どこが問題記号でどこが解凍選択肢か、正解はどれか >そう言った情報が機械的に判断できる必要があるんだが、それは可能なのか? このすべてどうやればいいかわかりません。
667 名前:デフォルトの名無しさん mailto:sage [2014/04/29(火) 20:11:16.39 ID:7Qss/xhP] 対象のPDFが最初の1本だけの場合、問題数は28、回答のパターンは5つかな? この分量だと全自動化は非効率すぎる コード書く手間を考えると手動でリストボックスを並べてった方が早い 全文をコピペしたあと、カッコの中に丸付き数字が入った部分を文字列検索してリストボックスに置き換え これぐらいはVBAでできるな 選択肢は丸数字、スペース、単語、スペースの繰り返しになってる行を検索、それ以外のパータンは手動で設定
668 名前:デフォルトの名無しさん mailto:sage [2014/04/29(火) 20:13:02.51 ID:7Qss/xhP] よく見たら全部画像じゃねーか まずはOCRからか こんなもんVBAの質問の範疇じゃないわ
669 名前:デフォルトの名無しさん mailto:sage [2014/05/03(土) 20:16:41.15 ID:zpOcxqmE] 何万回も計算とかするためにセルに入力されてる1000単位のデータを、いちいちシートから参照すると時間がかかりそうだから二次元配列に格納して取り扱ってるんですが、やっぱり計算に時間がかかるんで配列より早い方法ってないですか? そもそもシートから参照したほうが早かったりしますかね。
670 名前:デフォルトの名無しさん mailto:sage [2014/05/03(土) 20:20:45.14 ID:6uPX0+EP] その前にシートに計算式がてんこ盛りなら再計算をストップしてからするとか
671 名前:デフォルトの名無しさん mailto:sage [2014/05/03(土) 20:53:57.75 ID:Ucenml3N] >>669 すくなくともセル参照よりは配列を参照する方が早いというのが通説 頻繁に参照する場合は配列に入れてアクセスするのは常套手段 時間かかってるのが参照ではなく計算そのものなら、参照早くしてもあんまり効果ないだろ
672 名前:デフォルトの名無しさん mailto:sage [2014/05/03(土) 21:13:46.07 ID:pGt2sRew] >>669 計算量が多くてスピードが重要ならVBAじゃなくてせめてVBを使え
673 名前:デフォルトの名無しさん mailto:sage [2014/05/03(土) 21:20:32.55 ID:BzVjbdP5] >>66 > そもそもシートから参照したほうが早かったりしますかね。 1000単位のデータの内使うのがひとつだけとかの特殊な状況でない限り、ぜ〜〜〜っていあり得ない。 つーか、今配列使ってるならセル参照に変えてみなよ。
674 名前:デフォルトの名無しさん mailto:sage [2014/05/03(土) 22:48:42.50 ID:zpOcxqmE] どうも回答ありがとうございます。 配列のほうが早いみたいですね。 シートでの計算も一切してませんし、会社のPCなのでVBを導入することも難しいので 計算式を見直して速度を上げたいと思います。
675 名前:デフォルトの名無しさん mailto:sage [2014/05/03(土) 23:04:23.60 ID:pGt2sRew] まともなコンパイラも許可せずに、そんな大変な計算をさせるなんてどんなブラック企業だ
676 名前:デフォルトの名無しさん mailto:sage [2014/05/03(土) 23:53:50.92 ID:8kppz192] >>674 計算式を見直すんじゃなくて、処理を見直したほうがいいと思う
677 名前:デフォルトの名無しさん mailto:sage [2014/05/04(日) 10:30:37.54 ID:A7LETp9o] エクセルVBAのunicode文字列をdllに渡す処理のことで質問があるんだけど このスレでOKですか?
678 名前:デフォルトの名無しさん [2014/05/04(日) 10:46:31.65 ID:PkGldEjn] 構造体の変数が2つあるんですが 1つを他のもののコピーとしたいんですが 単に代入すると同一のものの参照となります。 そうじゃなくて構造体の全メンバの変数の値をコピーするにはどうするのが一般的ですか?
679 名前:デフォルトの名無しさん [2014/05/04(日) 10:47:16.38 ID:PkGldEjn] Structure Student Dim name as String Dim age as integer Dim sex as String Dim first_time_sex_date as Date End Structure Dim student(2) as Student student(1).name="Taro" student(1).age=16 student(1).sex="Male" student(1).first_time_sex_date="2012/7/7" student(2)=student(1) student(2).name="Jiro" みたいにすると変になる。
680 名前:デフォルトの名無しさん [2014/05/04(日) 10:48:20.51 ID:PkGldEjn] VBAでIEを操作するとき タブ(複数開いてる)でアクティブになっているページをgetするためには どういうコードになりますか?
681 名前:デフォルトの名無しさん [2014/05/04(日) 10:49:41.57 ID:PkGldEjn] あ、そういえばExcelで他シートをActivateしたらそのシートでActiveCellになるはずのセルのアドレスを そのシートをActivateせずに取り出す方法を以前発見したのですが それはどういう方法だったのでしょうか?
682 名前:デフォルトの名無しさん mailto:sage [2014/05/04(日) 14:59:19.38 ID:ifQjgP9H] >>678 構造体の全メンバをコピーする関数はないの? クラスによくある、cloneとか コピーには、Shallow Copy(浅いコピー)と、 Deep Copy(深いコピー)の2つがある 構造体の中に、構造体の参照があったらどうする? クラスの中にクラスの参照とか、または相互に入っていたら? さらに、2重、3重になっていたら? 深いコピーだと、参照なら本体を新しく作って、 本体もコピーするが、 浅いコピーだと、参照をコピーするだけなので、 本体は同じものを使ってしまう
683 名前:デフォルトの名無しさん [2014/05/04(日) 15:10:16.41 ID:PkGldEjn] >>682 すんません、なにも知らんです。 ExcelのVBAには全メンバコピーの方法ってないのですか? cloneってなにかのクラスのメンバメソッド? あれ、VBAはクラスって使えるの? ところで他言語でクラスの勉強はじめたけど、よく考えたら構造体とクラスって似てるよな。
684 名前:682 mailto:sage [2014/05/04(日) 17:21:28.68 ID:ifQjgP9H] VB.netには、Copy, Cloneがあるが、 VBAはV6仕様なので、無いかも? クラスはある クラスモジュールにクラスを定義して、new して使 なので、ここにCloneを自分で定義したら? 漏れもよく知らない 検索で調べただけだから、自分でも調べて それと、複数のスレで同じことを聞く、 マルチポストは禁止なので、どちらかを取り消すこと
685 名前:デフォルトの名無しさん mailto:sage [2014/05/04(日) 18:18:53.17 ID:MnWuoZnQ] >>683 >ところで他言語でクラスの勉強はじめたけど、よく考えたら構造体とクラスって似てるよな。 ちょっと待て。VBAは普通構造体というとユーザー定義型のことを指すけど、 VB.NetやC#の構造体とごっちゃに考えていないか? VB.Netとかの構造体でクラスと似ていると言うなら、 そりゃそうだろとしか言いようがない。と言うか、 どういう時にクラスを使ってどういう時に構造体を使うのかを調べれば すぐに分かると思う。
686 名前:デフォルトの名無しさん mailto:sage [2014/05/06(火) 22:58:33.18 ID:moIIdFlD] かなり低レベルな内容だとは思いますが、判らないので教えてください。 日付をmm/dd/yy形式で出力してくるログをyyyy/mm/dd形式で取り込みたいのですが、 普通にformat(date,"yyyy/mm/dd")みたいにするとうまくできません。 (たとえば05/05/14は、2014/05/05とならず、2005/05/14となってしまいます) とりあえず仕方なく前6桁と後ろ2桁で分離してくっつけなおすという格好悪い方法でやってますが、 もっとスマートなやり方があったら教えて欲しいです。 よろしくお願いします。
687 名前:デフォルトの名無しさん [2014/05/06(火) 23:12:00.35 ID:Avr/JzZk] 低レベルとは 0100011011010101 みたいな話だ。
688 名前:デフォルトの名無しさん mailto:sage [2014/05/07(水) 00:35:08.77 ID:uh4oWvq+] >>686 前5桁じゃなくて6桁? ログってことはテキストファイルだろうから、テキストファイルウィザードで日付→MDYを選択すればいい imo73.eek.jp/up/imo0105.png
689 名前:デフォルトの名無しさん mailto:sage [2014/05/07(水) 07:35:46.76 ID:SH7lri32] >>688 即レスありがとうございます。 そうです5桁でした。 そして対象が行ごとに違う内容が入ってくるログなのと、 読み込んだ日付を基準に処理を分岐させたいのでその方法は使えないです。
690 名前:デフォルトの名無しさん mailto:sage [2014/05/07(水) 08:31:27.71 ID:FZZA6k3k] >>689 > とりあえず仕方なく前6桁と後ろ2桁で分離してくっつけなおすという格好悪い方法 で、やれてるんじゃねーのかよ。 まあ、条件後だしする奴にはなに言っても無駄か...
691 名前:デフォルトの名無しさん mailto:sage [2014/05/07(水) 12:49:17.67 ID:oO9n6rpk] 次の行が読めなかったんだな。可哀想に。
692 名前:デフォルトの名無しさん [2014/05/07(水) 13:43:37.48 ID:rXgxEPuc] セールスマン問題にアニーリング法をうまく組み込めない…
693 名前:デフォルトの名無しさん mailto:sage [2014/05/07(水) 14:17:10.39 ID:uh4oWvq+] >>692 VBA無関係 データ構造,アルゴリズム,デザインパターン総合スレ 2 toro.2ch.net/test/read.cgi/tech/1362301811/
694 名前:デフォルトの名無しさん [2014/05/07(水) 14:52:43.45 ID:eMxnpyoF] >>689 方法はあまり変わらんけど、こんなのも有るよ moto = "05/07/14" Debug.Print "moto= " & moto moto20 = Left(moto, 6) & "20" & Right(moto, 2) Debug.Print Format(moto20, "yyyy/mm/dd") 2099年までこの方法は使える、2007では識別出来たけど、他Verは判らない。
695 名前:デフォルトの名無しさん mailto:sage [2014/05/07(水) 18:18:55.57 ID:MZ01fZnX] ゴミ
696 名前:デフォルトの名無しさん mailto:sage [2014/05/07(水) 22:57:09.28 ID:VZywwylY] >>686 Splitで"/"で分割して、年の部分だけ頭に"20"でもくっつけて、 順番かえて"/"で結合するようなんじゃダメ?
697 名前:デフォルトの名無しさん mailto:sage [2014/05/08(木) 00:00:54.73 ID:UhAEWxzw] 年が2000年代固定ってどうなのよ ログで99年が2099年ってどこの未来から来た人ですか
698 名前:デフォルトの名無しさん mailto:sage [2014/05/08(木) 00:46:43.35 ID:E+ainyFV] それはシステムの特性によって切り分ければいい話だ どのみち入力の年が2桁の時点で判断は必要になるわけで
699 名前:デフォルトの名無しさん mailto:sage [2014/05/08(木) 01:06:45.17 ID:8vH2dr8E] 年数の二桁→四桁変換はOSの設定に任せとけば良い。 とか思ったけど、書式指定でDateに変換する方法が無い罠だった。
700 名前:デフォルトの名無しさん mailto:sage [2014/05/08(木) 16:40:16.01 ID:UhAEWxzw] スマートなやり方ってのがどんなのをご希望か知らんが moto = "05/07/14" Debug.Print "moto= " & moto saki = DateSerial(Mid(moto, 7, 2), Mid(moto, 1, 2), Mid(moto, 4, 2)) Debug.Print Format(saki, "yyyy/mm/dd") まあこんな感じか
701 名前:デフォルトの名無しさん mailto:sage [2014/05/08(木) 18:22:31.60 ID:uOW3clqT] どうやっても大差ない moto = "05/07/14" saki = DateValue(Right(moto, 2) & "/" & Left(moto, 5)) Debug.Print Format(saki, "yyyy/mm/dd")
702 名前:デフォルトの名無しさん [2014/05/09(金) 10:23:43.29 ID:QVvO9eKk] ノートン 問題 裁判 ノートン 問題 裁判 ノートン 問題 裁判 ノートン 問題 裁判
703 名前:デフォルトの名無しさん [2014/06/12(木) 22:38:54.01 ID:JGtl8L6J] 日別の購入データの通し番号から、マスターを参照してジャンル分けして、ジャンルごとの合計金額を出したいです。 light.dotup.org/uploda/light.dotup.org28231.png ↑ データはこのような画像の通りにシート3つに分かれて存在しています。 どのようなマクロを組めばいいかお教え願いたいです。 ジャンルごとに変数というものを持たないといけないのでしょうか? 実際は母が使うので、ボタン一つで出来るのだとありがたいのですが・・・ 大変面倒な質問ですが、お願いします 具体的なコードを教えてください 本当に困っていますお願いします
704 名前:デフォルトの名無しさん mailto:sage [2014/06/12(木) 22:54:39.12 ID:LMWZ0+/Q] >>703 ピボットテーブル使うってのは? 答えに全くなってないわけだが、、、、
705 名前:デフォルトの名無しさん [2014/06/12(木) 22:55:17.66 ID:JGtl8L6J] >>704 ボタンひとつで計算してくれるようにしたいんですが そのコードを教えてください
706 名前:デフォルトの名無しさん mailto:sage [2014/06/13(金) 00:07:26.49 ID:3uExzG0V] 凄まじいマルチw
707 名前:デフォルトの名無しさん mailto:sage [2014/06/13(金) 10:30:47.32 ID:jJMpWNsU] >>705 コード作ってもいいが保守するのが大変。 まずは標準の機能でできないものかトライするよろし。
708 名前:デフォルトの名無しさん mailto:sage [2014/06/14(土) 15:16:41.92 ID:UnUM1hDE] こんにちは。セルの不一致部分を取り出して、1から並べ直し、 修正したデータを入力するというマクロを作成しているのですが、 同じ列で複数の間違いがあった場合、iを進めないように、コメントアウトしているif文を入れたのですが、 そうすると、2行目で 実行時エラー1004 アプリケーション定義またはオブジェクト定義のエラーです が表示されてしまいます。 列に間違いは2つ以上ないということで、コメントアウト部分を削除したままなら問題なく稼働するのですが、 この1文を入れるとどうしても進みません。 Arrayには、不一致部分のセルの座標が入っています。 全然ここから進まなくて困っていますので、どうかご教授お願い致します。 Do ws.Cells(Array_l(j), Array_r(j)).Value = s1.Cells(i + 1, Array_r(j)).Value 'B1の数値を修正する ws.Cells(Array_l(j), Array_r(j)).Interior.Color = xlNone 'B1のセル背景を元に戻す ws2.Cells(Array_l(j), Array_r(j)).Interior.Color = xlNone 'B2のセル背景を元に戻す 'If Array_l(j) = Array_l(j + 1) Then i = i - 1 'End If j = j + 1 i = i + 1 If Array_l(i) = Empty Then Exit Do Loop
709 名前:デフォルトの名無しさん mailto:sage [2014/06/14(土) 15:23:57.74 ID:UnUM1hDE] コメントアウトしている部分は i=i-1 の部分です 'つけ忘れです、すみません。
710 名前:デフォルトの名無しさん mailto:sage [2014/06/14(土) 16:30:49.01 ID:Je/qq0DA] >>708 省略してる部分が多すぎて何がやりたいかわからん ステップ実行するかなんかでロジック追ってみたら 昔ならこれフロー書いてみろとか言われるんだろうな しかし、変数名って大事だなと思うわ
711 名前:デフォルトの名無しさん mailto:sage [2014/06/14(土) 17:00:57.85 ID:UnUM1hDE] >>710 返信ありがとうございます iを調節するIF文を入れるとなぜか s1.Cells(i + 1, Array_r(j)).Value にエラーが出るんです。 s1.Cells( 2 , 4 ).Value という風に変えてもエラーが出るんです。 IF文を消せば消えるんですが。
712 名前:デフォルトの名無しさん mailto:sage [2014/06/14(土) 17:23:19.85 ID:UnUM1hDE] 事故解決できました!ありがとうございました!
713 名前:デフォルトの名無しさん mailto:sage [2014/06/14(土) 22:49:14.29 ID:jhtRx4NU] KING SOFTのVBAは完全互換ですか?
714 名前:デフォルトの名無しさん mailto:sage [2014/06/15(日) 06:28:01.21 ID:sZLgElUH] >>713 何と?
715 名前:デフォルトの名無しさん mailto:sage [2014/06/15(日) 15:24:53.85 ID:+yTvRbGG] まったく同じプログラムなのに保存したらファイルサイズが違った これでは完全互換とは言えない
716 名前:デフォルトの名無しさん [2014/06/17(火) 03:20:53.05 ID:HVt3rccc] >>715 エクセルでブックを別PCにコピーして開き、 何もせずにそのまま保存してもファイルサイズが変わることがある