★1 質問テンプレ(雛形)は用意しませんが、OSとExcelのバージョンは必ず書きましょう。 ★2 ExcelのVBA以外の部分に関する質問はNGです。 但し、VBA無しでも出来ることだが、あえてVBAでやりたいって物に関してはOK。 ★3 ExcelのVBE(Visual Basic Editor)を使うとしても、VBAの分野以外に関してはスレ違いです。 VBAとは、『Visual Basic for Application』の略で Application ├Workbooks |└Workbook | ├Worksheets | |└Worksheet というApplication以下のオブジェクトを、VB言語で操作するものを指します。 例えExcel付属のVBE(Visual Basic Editor)を利用しようとも、このApplication以下のブックやシート、 セルやオブジェクト等を操作するもの以外はVBA分野の話ではないので、ここでは聞かないでください。 ★4 とりあえず、Excelのインスタンスを作らずにVB6で出来ることは全てスレ違いだと思ってください。 ★5 レベルはどうあれ、ここはプログラマ用の板スレです。プログラマとは、自分でプログラムを組み コードを書く人の事なので、自分でやるきは全く無く、丸投げしようって人はお断りです。 ヒントを貰えばあとは自力でなんとかしますって人のみどうぞ。
乙
5 :
デフォルトの名無しさん :2007/09/18(火) 22:54:04
−−−−−−−−−− |1000|1100|以上| −−−−−−−−−− | | 900|以下| −−−−−−−−−− こんな感じのデータが縦横に沢山入っているワークシートなんですが 1000の数値を監視し、1100以上や900以下になったら 1000のセルの色(既に1000ではなくなっているけど)を変えるというものを VBAで作ろうとしています。 1000の部分は自動で数値が刻々と変わり 1100、900、以上、以下のセルに関しては事前に手入力します。 WorkSheetのChangeイベントでワークシートの全セルの変化を全て監視し 変化のあったセルが1000の位置だったら(2つ右のセルの内容が「以上」かどうかで判定するつもりです) 1000の右の1100や右下の900と比較して 以上なら1000の文字列を青、以下なら赤といった感じで セルの色を青や赤に変えたいんですが VBA初心者なんでセルの色を変えるのはともかく 右隣や2つ右、右下といった位置のセルの内容を取得するには どんなソースを書けばいいのか検討もつきません_| ̄|○ 環境はWin2000+EXCEL2000です
cells.offset
VBAが必要かどうかから考えろ シートの関数も知らないで聞いてる訳じゃないだろ?
9 :
5 :2007/09/18(火) 23:15:56
>>6 .
offsetが目的に使えそうです。
有難うございます。
>>7 すんません、関数もVBAもほとんど知りません。
大昔にC言語でゴリゴリソース書いていたことはあるのですが・・・・
10 :
5 :2007/09/18(火) 23:19:41
>>8 とりあえず条件付き書式で作ってみたんですが
空白の部分にも1000を入れる必要があるのと
条件を満たした時に音を鳴らしたいのでVBA化するつもりです。
(音の鳴らし方は調べて分かりました)
11 :
デフォルトの名無しさん :2007/09/19(水) 21:40:05
現在、あるフォルダ内のcsvを読み込んで進捗表に反映させるマクロを使っているんですが、 その後にフォルダとその下層のファイルをクリップボードに張り付ける事は可能ですか? 可能であればヒントだけでも頂ければ・・・
クリップボードとか不安定な領域じゃなく、FSO使ってフォルダオブジェクトとして保持すればいいような
14 :
デフォルトの名無しさん :2007/09/20(木) 20:12:47
INDIRECT関数をVBA上で作りたいと思っています。 たとえば、sheet2にある(B,C)のセルにあるものを参照しようとして、 Function INDIRECT2(B, C) Dim SHEETNAME As Worksheet Set SHEETNAME = Worksheets("sheet2") INDIRECT2 = SHEETNAME.Cells(B, C) End Function で動かすと、値が帰ってきます。 ここで、"sheet2"を変数としてに扱おうと考えて、 Function INDIRECT2(B, C) Dim SHEETNAME As Worksheet MOJI = "Sheet2" Set SHEETNAME = Worksheets(MOJI) INDIRECT2 = SHEETNAME.Cells(B, C) End Function と書くと#value!になってしまいます。 worksheet名を変数で指定することはできないのでしょうか?
ツッコミどころが多すぎてどこから突っ込んで良いものやら・・・ とりあえず INDIRECT2 = SHEETNAME.Cells(B, C) は INDIRECT2 = SHEETNAME.Cells(B, C).Value こうしろ
上のコードで動くのか。。。
Dim fName , tmp fName = Combobox1.Value With CreateObject("Scripting.FileSystemObject") If LCase(.GetExtensionName(fName)) = "txt" & vbCrLf Then tmp = Split(fName, ".txt" & vbCrLf) For Each fName In tmp Msgbox fName Next fName End If End With End Sub こんな感じで、コンボボックス内のテキストファイル名を取り出す処理はできたのですが、 最後に一回空白が返ってきてしまいます。 どのようにすれば改善できるでしょうか?
あのねぇ・・・Valueにリストを入れるなよ・・・
19 :
14 :2007/09/21(金) 14:05:42
ありがとうございました。 Function INDIRECT2(B, C) Dim SHEETNAME As Worksheet MOJI = "Sheet2" Set SHEETNAME = Worksheets(MOJI) INDIRECT2 = SHEETNAME.Cells(B, C).value End Function にすることによって、同一ブックの中でのセルの参照ができるようになりました。 ここで、 MOJI="[002.xls]sheet2"のように、ほかのブックの値を参照させることはできないのでしょうか?
20 :
デフォルトの名無しさん :2007/09/21(金) 20:32:14
application.workbooks(BookName).worksheets(SheetName)
21 :
デフォルトの名無しさん :2007/09/22(土) 09:53:52
VBA歴3ヶ月の初心者なんですが質問させて下さい。 WindowsXPでエクセル2003を使用しています。 下記のように a -- b -- c -- d と縦に並んでいる文字列をコピーして 行と列を入れ替えて、それぞの文字を2つずつに 増やして貼り付けしたいのですが、これは可能でしょうか? a│a│b│b│c│c│d│d│ いろいろ考えたのですが上手い方法が思いつきません。 もし可能でしたらヒントを頂けないでしょうか? よろしくお願い致します。
可能 range For each
23 :
21 :2007/09/22(土) 14:23:27
22さんありがとうございます。 22さんのヒントを見てから 1時間ぐらいネットで調べたりして考えたんですが やっぱり分かりません(T_T) 私の職場は女性ばかりでプログラムに強い人が いなくて職場では誰にも聞けません。。 もし良かったらもう少しヒントを頂けないでしょうか? よろしくお願い致します。
>>23 説明するの面倒だから、一セルずつコピーしたら?
25 :
21 :2007/09/22(土) 15:24:48
>>24 さん
例ではa〜dまでしか書きませんでしたが、実際は膨大な量なんですよ(^^;)
1セルずつコピーしてたらものすごく時間がかかるんです。
この問題さえクリア出来れば全ての作業を自動化出来るのですが・・・。
お手数おかけして申し訳ありませんでした。
私の今の実力では無理ですが、いつかは自分で出来るように頑張ります!
>>25 まさか、描画や再計算を止めてないって落ちはないよね?
あなたの言う膨大がどれほどか判らないけれど、100や200のセルのコピーくらい大して時間掛かりませんが。
27 :
21 :2007/09/22(土) 16:18:45
>>25 さん
プログラム完成してないので再計算を止めてないも何も動かしていません(T_T)
200のセルのコピーぐらい大して時間がかからないとの事ですが、
すべてのセルを2倍にして、縦横入れ替えていたらミスも発生するし
作業時間が勿体ないと感じるのです。
その時間が他の仕事に当てられたらと思い、家で考えていました。
もっと勉強してから出直して来ます。
28 :
21 :2007/09/22(土) 16:19:33
すいません、↑間違えました
>>26 さんでした(^^;)
大して時間がかからないとは、手作業でやってもということではなく、 マクロで実行したときの話だと思うが。
21はプログラムが完成していないと言っているので手作業の事じゃないの? 完成してりゃあ100や200のコピーぐらいすぐ終わるっしょ。 完成して無い奴に 100や200のセルのコピーくらい大して時間掛かりませんが とか言っても意味無いっしょw
ちょっと待て、もしかしたら>21はマクロ云々の話をしていないのではないか? # だとしたら鼬害なのだが。
ちょっと待て、実は24も分かってないとか。
問題を整理すると、>21は手作業では手間が掛かることをマクロでやりたい。 しかし、セルを一つずつコピーするようなマクロも書けないので一から教えろ。 と言う話なのかな?
For Eachが理解できないやつにExcel VBAを教えるのも無理な話 素直に手動でコピって、形式を選択して貼り付けで行列変換しとけ
ここの住人はやっぱり冷たいな。 分かるんなら正解かいてやれよ。
自演乙
いや冷たいのは事実
能書きはこくけどサンプルコードのひとつもだせない それがVBAスレクオリティ
>>2 ★5なので、丸投げ野郎やコード呉厨に冷たいのは当然
それを叩いてるのは自演か過去に丸投げやクレクレして冷たくあしらわれた事が有る奴等w
クレクレが必死だな
ヒント:dim文が3行set文2行コード3行でできる
ハズレ
>>31 の鼬害がよめなかった俺はゆとり。再変換して納得。
>>21 別のシートのA1に
=INDEX(シート名!$A:$A,ROUNDUP(COLUMN()/2,0),1)
といれて横にフィルすれば俺の脳内ではいけるけど
128行を超えるとExcel2003は256列しかないで無理。
なんで、もし129行目からは下の行に表示するならA1に
=INDEX($A:$A,ROUNDUP(COLUMN()/2,0)+(ROW()-1)*128,1)
でフィルすれば良い感じ
このままじゃ板違いなんで、同じことをVBAでやると
Dim Rng, rngValue, col%, r%
Rng = sh.Range(sh.Range("A1"), sh.Range("A65536").End(xlUp))
col = 1: r = 1
For Each rngValue In Rng
Cells(r, col) = rngValue: Cells(r, col + 1) = rngValue
col = col + 2: If col > 256 Then col = 1: r = r + 1
Next
まぁ参考程度に。
てか、ここの住人なら俺なんかより良いコードかけるだろうに
ホントいけずだな
44 :
デフォルトの名無しさん :2007/09/23(日) 05:39:06
Sub aaa() a = 0 Do Until a 〉127 a = a + 1 c = a * 2 b = 1 Cells(b,c -1) = Cells(a,b) Cells(b,c) = Cells(a,b) End Sub もういないかな? これ貼り付けれ 列の端っこまでの制限はあるが ソースが美しくないとかの批判は受け付けねw 作るより打つほうに時間かかる始末 携帯からだと死ねるw お前らもうちょい優しく教えてやれやwwwwwwwwwwwww
美しい美しくない以前に・・・・・
46 :
デフォルトの名無しさん :2007/09/23(日) 05:51:13
ダメならダメとはっきりいってください ソースのヒントも書かない糞野郎さん
結局質問スレとして機能してねぇのなここ ビジネスsoft板のと統合しちまえよ こんな糞スレ要らん
Dim RngA As Range
Dim RngB As Range
Dim i As Long
Set RngA = Range("A1:A5") 'コピー元セル
Set RngB = Range("B1") 'コピー先セルの始点
For i = 1 To RngA.Count
Range(RngB.Offset(0, i * 2 - 2), RngB.Offset(0, i * 2 - 1)) = RngA.Cells(i)
Next
中途半端だけど普通はこんなもんか?
ハードコードにすればRngA,Bのくだりはいらないけど。
ただ、やっぱりコード0行で来るスレではないと思うぞここは。
>>44 はループは閉じるとこから始めような。
Excel2000で、officeのクリップボードではなくWindowsのクリップボードに変数の値をコピーする方法を教えてください
>>49 DataObject使うかWin32API使え
>>2 ★5なので、あとは自分で頑張ろう
51 :
デフォルトの名無しさん :2007/09/23(日) 13:36:33
〉〉48 ああすまん Loop書きわ忘れてたな 一応VBA歴3ヶ月って書いてあったから行列の入れ替えと二列づつて書く方法がたまたま思いつかなかったんじゃないかね? そのヒントすら教えんで ただ罵倒してるのにイラついたもんで ヒントくださいっていってるしな
そして誤字 脱字orz
誰か罵倒しているのか?
Rangeオブジェクト と For Eachステートメントを書いといたのに、
「ヒントすら教えん」とか言われてモナ
これ以上どうしろっつーんだよw
コード丸々書けと?
Rangeでヘルプ引けば
--------------------------------------------
次の使用例は、シート 1 のセル範囲 A1:D10 に対してループを行います。
セルの値が 0.001 未満の場合は、値をゼロ (0) に置き換えます。
For Each c in Worksheets("Sheet1").Range("A1:D10")
If c.Value < .001 Then
c.Value = 0
End If
Next c
-----------------------------------------
なんて出てきて、よく読んでみれば
「あー範囲をセル単位でループして値をセットすりゃ良いんだな」って
ぐらい、ちょっと脳みそが有ればすぐ分かるだろ
残念ながら最低限の能力ラインってのは存在するんだわ
自分が相手にされなかった経験があるからって、いいかげん怨み節を垂れ流すのは
やめてもらえんもんかね?
>>51
>>54 考え自体は肯定も否定もしないがそのレスは何なのw
そう思ってたからみんなスルーしてただけだろ。
たまーに質問者放置でコード談義に盛り上がり、たまーに優しい人がいて、
基本は「スレ違い」で終わるだけのスレじゃんw
>>55 まぁここはExcel VBA雑談スレだからなぁ
> 考え自体は肯定も否定もしないがそのレスは何なのw > そう思ってたからみんなスルーしてただけだろ。 なるほどな 「みんなもそう思ってる」とかその系統か クレクレ脳を基準に「ヒントもない」とか強弁しなさんなよ
58 :
デフォルトの名無しさん :2007/09/24(月) 14:13:20
OS:winxp2 ver:2003 宣言セクションでモジュールレベル変数やパブリック変数を 宣言する際に、初期値を格納したのですが、どう記述すればいいんでしょうか?
59 :
58 :2007/09/24(月) 14:14:27
× 初期値を格納したのですが、・・・ ↓ ○ 初期値を格納したいのですが、・・・
60 :
デフォルトの名無しさん :2007/09/24(月) 14:42:10
無理なバージョンは無理だから まとめて初期値入れるプロシージャでもつくっとけ
残念ながら言語仕様で宣言と初期化は同時にできないんです(><
62 :
デフォルトの名無しさん :2007/09/24(月) 15:16:18
Workbook_Open() か UserForm_Initialize()
[VBA プロジェクト オブジェクト モデルへのアクセスを信頼する] をVBAから操作するにはどうすればよいのでしょうか?
>>63 それが出来ちゃったら"脆弱性"と呼ばれるだろうなw
65 :
デフォルトの名無しさん :2007/09/25(火) 00:31:37
>>21 さんのやりたいことってVBA使わなくても実現できますよ。
a
b
c
d
a
b
c
d
というデータを用意して,並べ替えたら
a
a
b
b
c
c
d
d
になるでしょ。
その後コピーしてから「形式を選択して貼り付け」します。
この時「行列を入れ替える」をチェックしてね。
すると
aabbccdd
になるよ。
66 :
デフォルトの名無しさん :2007/09/25(火) 00:44:51
VBみたいにuserformにメニューバーて追加できますか? ツールバーなら出来るみたいだけど。 メニューエディタは見当たらないし仕様上無理ですか?
>>65 ついでに「それをマクロ記録してショートカットキー登録」すれば十分だったりするかなw
>>66 無理
ただしOCX自作するならその限りではない
69 :
デフォルトの名無しさん :2007/09/25(火) 03:01:24
>>68 素早い回答ありがとうございます。
OCX?ですか。多分無理そうなのであきらめます…。
○Sheet1.Activate Range("A1:C3").Borders.Linestyle = True ○Sheet1.Activate Range(Cells(1,1),Cells(3,3)).Borders.Linestyle = True ○Sheet1.Range("A1:C3").Borders.Linestyle = True ×Sheet1.Range(Cells(1,1),Cells(3,3)).Borders.Linestyle = True 動いたからいいんだけど、どうして一番下だけ駄目なのか理由がわからなくて。 下が駄目なら3番目も駄目なような気がするんだけど?
71 :
デフォルトの名無しさん :2007/09/25(火) 20:54:34
3番目はそれで特定できるけど 下はSheet1.Cells(1,1)じゃないとダメってことだろ Sheet1.Activateすれば下でも通るでしょ
それじゃ回答になっていない Sheet1.Range(Cells(hoge))って記法だと Rangeまでは上位オブジェクトが参照できている しかし(Cells(hoge))だとCellsの上位オブジェクトが分からない だからその場合VBA側で「とりあえずアクティブシートを参照」するわけだ これだと期待する動作かどうか判然としない Activate,Select系を使わないのが望ましいというのは、こういうことから つまり面倒でも.Sheet1.Range(Sheet1.Cells(hoge,hoge),Sheet1.Cells(hoge2,hoge2)) って記法にしなくてはならない ソースが読みづらくなるので、こう言うときは通常はWithステートメントを使う
73 :
デフォルトの名無しさん :2007/09/25(火) 21:28:21
とりあえずじゃないだろ
65はアホ?
>>70 Sheet1.Range(Range("A1").Address, Cells(3, 3).Address).Borders.LineStyle = True
これはOKだったりして
76 :
デフォルトの名無しさん :2007/09/26(水) 19:42:21
Excelで入力規則でリストを設定するとセルがコンボボックスになります。 これと同じようにセルにボタンのような機能を持たせる事は可能でしょうか? 見た目はボタンでなくてもいいです。 実現したいことはあるセルのボタンをクリックすると隣のセルの入力文字を 取得したいのです。通常のコントロールボックスのボタンだとどのセルにも 置けてしまうので隣のセルの文字列取得はできないと思うのです。 VBで言えばSPREADの一つのセルをボタン型にしたようなものです。 要はクリックされれば隣のセルの文字列を取得しメッセージボックスで表示 させるような処理がしたいのです。
SelectionChangeイベントでそれなりには作れる
コントロールのボタンでそれなりには作れる(配置されてるセルを取得できるので)
79 :
デフォルトの名無しさん :2007/09/26(水) 22:00:11
>>78 配置されたセルが取得できるとは知りませんでした。
セル間の微妙な位置にも置けると思うので・・・
配置されたセルの取得方法はどうすればいいのでしょうか?
ヘルプ嫁
for i=1 to 100 if cells(i,1).value ="飛ばす" then □ ○○ next i □で、今回のループだけ抜けたいときはどうすればいいんでしょう (ようするに、A列に特定文字が入ってるときは○○を実行させたくない) nextだとエラー、 end forだとfor〜next自体が終わってしまう elseで囲めばいいんだけど○○の部分が凄く長くて見通しが悪くなるので なんかどうにかしたかった。
そこでgotoですぜ。旦那w
83 :
デフォルトの名無しさん :2007/09/26(水) 22:56:57
>>80 すみません。うまく見つける事ができません。
if not 〜 end if
>>79 CommandButton1だったら
CommandButton1.BottomRightCell.Address
とか
87 :
デフォルトの名無しさん :2007/09/27(木) 01:19:33
10進小数を2進小数に直すプログラムを作っています このプログラムを使って0.375を2進数に直したいのですが 0.375はこのプログラムのどこに入れたらよいでしょうか? プログラム自体間違えてたら 間違えている場所を指摘してくれると幸いです Sub m進小数() p = Cells(1, 1) q = Cells(1, 2) k = 1 While p > 0 a = Int(p * 2) q = a * 0.1 ^ k + q p = p * 2 - Int(p * 2) k = k + 1 Wend Cells(2, 1) = 0.1 ^ k + q End Sub
Cells(1, 1)
89 :
デフォルトの名無しさん :2007/09/27(木) 09:27:59
多数のファイルの、それぞれ同一の名前のシート内に、 特定の文字列があるかどうかを検索して、できればそれを削除したいのですが、 どうすれば可能でしょうか? ↓のマクロではシートを指定できず、削除することもできません。 Sub Macro() With Application.FileSearch .NewSearch .LookIn = "C:\Documents" .TextOrProperty = "NaN" .MatchTextExactly = True .FileType = msoFileTypeAllFiles .Execute For Each f In .FoundFiles MsgBox f Next f End With End Sub
あたりまえ
へー、そんなメソッドがあったのか 知らんかった お礼にヒントをあげよう Sub SearchXLS() Dim wbkTemp As Workbook For Each wbkTemp In Application.Workbooks Debug.Print wbkTemp.Name Debug.Print wbkTemp.Worksheets(1).Name Call wkbTemp.Close(False) Next End Sub
92 :
デフォルトの名無しさん :2007/09/27(木) 23:09:36
>>86 回答ありがとうございます。
やっと調査できるきっかけができました。
押されたコマンドボタンのオブジェクトは どうやって取得すればよいのでしょうか?
OSはXP、エクセルは2000を使っています。 VBAでソルバーの作業を記録して、実行しようとするとエラーが出ます。 VBAでソルバーは使えないのでしょうか? 使えるのであれば、是非方法を教えてください。お願いします。
96 :
デフォルトの名無しさん :2007/09/29(土) 21:09:22
C、C++のincludeにあたる機能はあるのでしょうか 他のSheet(というかモジュール)のマクロ関数を呼びたいのですが・・・よろしくお願いします。
97 :
96 :2007/09/29(土) 21:23:05
検索ワード変えたら見つかりました、すんまそん>Run
98 :
デフォルトの名無しさん :2007/10/01(月) 01:53:56
■長さ0の空白をempty値にしない方法教えてください 次のような代入をすると、右側のセルの""(長さ0の空白)が左側にはempty値に変換されて代入されます Sheets("Sheet1").Range("A1:Z1").Value = Sheets("Sheet2").Range("A1:Z1").Value もともとのデータで0と区別するために、あえて""が入ってるので、empty値に換えて欲しくないのです。 そもそも、VBAで Sheets("Sheet1").Range("A1:Z1").Value = "" と入れると、各セルにはempty値が入るみたいです。 (excel 2000、windows 2000) 以上、よろしく
>>98 Sub test()
[A1].NumberFormat = "@"
[A1].Value = ""
Debug.Print TypeName([A1].Value)
[A1].NumberFormatLocal = "G/標準"
[A1].Value = ""
Debug.Print TypeName([A1].Value)
End Sub
「Value = ""」の代入をするとEmpty値が入るのではなく
表示形式「G/標準」のセルにNullStringを代入するとEmpty値として扱われる
NullString("")は文字通りString(文字列)なんだから、文字列として扱って欲しければ
文字列の表示形式である「@」を設定してから代入すればいい
あとは値(Value)の代入ではなくセルのコピーを行ってもいいし
NullStringを返す数式「=""」を入力してやる手もある
[A1].Formula = "="""""
>>99 ありがとうございます、こんな感じでOKですね。
Sheets("Sheet1").Range("A1:Z1").NumberFormat = "@"
Sheets("Sheet1").Range("A1:Z1").Value = Sheets("Sheet2").Range("A1:Z1").Value
Sheets("Sheet1").Range("A1:Z1").NumberFormat = Sheets("Sheet2").Range("A1:Z1").NumberFormat
■セルのコピーとは、Selection.Copyとかですかね?
処理中にシートの切り替えとかの操作により、影響を受けそうな感じで使いたくないです
偉そうな弁舌はオブジェクト構造を理解してからにしな
今日の日付で保存したいのですが・・・ 1001.xls みたいに
そんぐらいググレカス
>>102 つ[time()]
つ[localtime()]
つ[strftime()]
つ[fopen()]
いけね、Cスレじゃなかった。
糞VBAなんて偉いやつは使わん、いいかげんに使えるから良いのさ
CheckBoxのオブジェクト名を変数に置き換える事って可能ですか? For~Nextで複数のCheckBoxを使いたいと思っているのですが上手く行きません
108 :
107 :2007/10/03(水) 10:27:19
OSは2000でExcel2002です、連投すいません
>>108 Excel コントロール配列
でググってみ
110 :
デフォルトの名無しさん :2007/10/04(木) 01:57:44
ちょい質問です。 クラスのインスタンスを生成する方法として 下記の2つの方法に機能的な違いはありますか?? 【方法@】 Dim myObj As class Set myObj = New class 【方法A】 Dim myObj As New class Aはただ単に@を1行にまとめただけ???
Sub 桁合わせる() Dim aaa As Range Application.DisplayAlerts = False On Error Resume Next Set aaa = Application.InputBox(prompt:="セル範囲を指定してください", Title:="桁を合わせます", Type:=8) On Error GoTo 0 Application.DisplayAlerts = True If aaa Is Nothing Then MsgBox ("終了します") Exit Sub Else Select Case aaa Case Is >= 100 aaa.NumberFormatLocal = "0" Case 10 To 99 aaa.NumberFormatLocal = "0.0" Case 1 To 9 aaa.NumberFormatLocal = "0.00" Case Is <= 0 aaa.NumberFormatLocal = "0.000" End Select End If End Sub 単一セルに対してなら処理できるのですが、セル範囲指定だと、型が一致しなくなってしまいます それと上記のままだと、数値が0以下のとき(0.123456789なら0.123って表示したい)うまく動作しません なので変数でSingleを宣言したら、今度は整数が処理できなくなってしまいました どこを直したら、いいでしょうか つたないソースですが、よろしくお願いします
>>111 Sub 桁合わせる()
Dim aaa As Range
Dim myCell As Range
省略
Else
For Each myCell In aaa
Select Case myCell.Value
Case Is >= 100
myCell.NumberFormatLocal = "0"
Case 10 To 99
myCell.NumberFormatLocal = "0.0"
Case 1 To 9
myCell.NumberFormatLocal = "0.00"
Case Is < 1
myCell.NumberFormatLocal = "0.000"
End Select
Next
End If
End Sub
>数値が0以下のとき(0.123456789なら0.123って表示したい)うまく動作しません
0.123456789は0より大きい数値だから0以下が条件では動作しない
今のエクセルは
>>111 で動くほどおばかさんにもやさしいのか
116 :
デフォルトの名無しさん :2007/10/04(木) 15:44:12
ハズレ
119 :
デフォルトの名無しさん :2007/10/04(木) 21:56:38
とあるフォルダを指定して、そのフォルダ配下(下位フォルダを含めて)のファイルを 探してデータを更新するというマクロを作成しようとしています。 (Microsoft Scripting Runtimeを参照設定しています) Dim FSO As FileSystemObject Dim dataFolder As Folder Dim pathName As String ←指定するフォルダ名 Set FSO = CreateObject("Scripting.FileSystemObject") dataFolder = FSO.GetFolder(pathName) … とやりたいのですが、dataFolderの設定を入れようとすると 「As folder」と 変換されてしまってうまくいきません。 他は大丈夫でFolderの指定だけできないので自分の書いたソースが悪いと思うのですが どうにも見当がつきません。 何をチェックすると解決できるのでしょうか?
とりあえず Set dataFolder = FSO.GetFolder(pathName) な
>>110 機能的な違いはないが、MS推奨では宣言と初期化を分けるように書かれている
オブジェクト指向云々は一切関係ない
コーディング規約の問題
>>119 オブジェクトブラウザ見れ
Dim objFSO As Scripting.FileSystemObject
Dim objFld As Scripting.Folder
Dim objFile As Scripting.File
Set objFSO = New Scripting.FileSystemObject
Set objFld = objFSO.GetFolder(ThisWorkbook.Path)
For Each objFile In objFld.Files
Debug.Print objFile.Name
Next
Set objFile = Nothing
Set objFld = Nothing
Set objFSO = Nothing
Set objFile = Nothing
Set objFld = Nothing
Set objFSO = Nothing
分かると思うけど後半3行は単なるコピペミスなので気にしないこと
123 :
110 :2007/10/05(金) 02:47:11
>>121 なるほど!さんくすです!勉強になりました!
嘘(or間違い)を見て勉強になったとは、これ如何に?
失敗から学べることは多いが 性交から学べることは何一つない
126 :
119 :2007/10/05(金) 19:12:20
>>120-121 ありがとうございます。
参考にしながら1から作り直したところ今のところはうまくいっています。
Setで設定してなかったから駄目だった、ということなのでしょうか。
教えてくださってありがとうございました。
半可通が朝っぱらから何を語ってんだか
128 :
デフォルトの名無しさん :2007/10/06(土) 07:12:43
能書きスレ
>>114 とても勉強になりました。ありがとうございます
>>110 以前どこかで
(1)のやり方の方にしないとNothingにしても
メモリが解放されないと聞いた。
んなーこたーない
別にnothingでメモリが開放されるわけじゃないから正解
そうなん?でもnothingしないと解放してくれないときもあるぞ
相互参照した場合、どっちかを明示的にnothingしないとメモリが残った
Nothingはあくまでもデストラクタを呼びつつ参照先を消去するだけ デストラクタが解放を拒んだらそこでリークになる
137 :
デフォルトの名無しさん :2007/10/07(日) 14:28:33
WindowsXP、エクセル2003を使用しています。 VBAで引数に範囲があるWorksheet関数を使用したいのですが VBA上の配列を範囲に指定することが出来ません。 どのようにすれば、使用できるのかご教授願います。 RANK(数値,範囲,順序) Dim Hht(9) As Double Dim i As Long 中略 Hrank = WorksheetFunction.rank(Hht(i), Hht) Hhtで型が一致しませんとエラーがでる。
これはひどい
139 :
デフォルトの名無しさん :2007/10/07(日) 16:00:44
皆さんこんにちは この連休でデーター仕事を行なっていますが、 なにせ未熟者、手作業で遅々として進みません。 皆さんのお力お借りしたいです、よろしくお願いいたします。 以下のようなデーターがありまして、 黒★の列は時間なのですが、 これを一秒ごとに行を空けたいのです。 時間は5秒毎というわけではなく、10秒であったり、 18秒であったりとランダムに出現します。 この表であれば各4行づつ空けたいのです。 他の列は空白でかまいません。時間さえ一秒ごとに埋まってくれれば…。 どなたか教えていただけませんか? ググレば出て来るのなら、ググレカスでもかまいません、 なんでもアドバイスよろしくお願いいたします。 ★ T1|No. 1|34.4149|135.31245|10.7|2007/9/12|5:18:30|WGS84|-9999.9|-9999.9 T1|No. 2|34.4149|135.31245|11.7|2007/9/12|5:18:35|WGS84|-9999.9|-9999.9 T1|No. 3|34.4149|135.31245|13.6|2007/9/12|5:18:40|WGS84|-9999.9|-9999.9 T1|No. 4|34.4149|135.31245|14.6|2007/9/12|5:18:45|WGS84|-9999.9|-9999.9 T1|No. 5|34.4149|135.31245|14.6|2007/9/12|5:18:50|WGS84|-9999.9|-9999.9
140 :
139 :2007/10/07(日) 16:04:40
>他の列は空白でかまいません。時間さえ一秒ごとに埋まってくれれば…。 × 他のセルは空白でかまいません。時間さえ一秒ごとに埋まってくれれば…。○ すみません。説明が悪いです。
>>139 5:18:30のセルを選択5:18:30を変数に入れる
カーソルをひとつ下に5:18:35を変数に入れる
2つの変数から差の秒数を取得
秒数だけ繰り返し行を挿入
1秒増やした時間をセルに入れながらカーソルを下に移動
以上を繰り返す
考え方は正しいけど、それだと実行速度的に現実的じゃないし、 シート行数が有限であるので判定が面倒くさくなる 最終時間と開始時間との差を導出して、開始時間から終了時間まで1秒づつステップしたカウント数を算出 Yにそのカウント数、Xに10個という配列を作る 配列を開始時間から最終時間まで1秒をステップした数で初期化 データを読み出して一致する時間があればデータをセット 終わったら書き出す こんでいいはず
144 :
デフォルトの名無しさん :2007/10/07(日) 19:44:01
>>139 なんか、過去スレでも、ほとんど同じ質問を教えてあげた気がする。
素直に142のいう通りにやったらいいと思う。
ちなみに、2つの秒差を求める式(Date2-Date1)は、
変数=DateDiff("s",Date1,Date2)
145 :
デフォルトの名無しさん :2007/10/07(日) 20:26:50
やりかたくらいはわかっているんだろ
146 :
137 :2007/10/07(日) 21:13:17
>>141 レスありがとう御座います。
Rangeの使い方がわまりません。
コードの書き方を示して頂けないでしょうか?
このスレをRangeで検索
>>146 Public Sub OshietekunTruth()
dim rngAnswer as range
dim rngOshiete as range
dim blnRes as boolean
set rngAnswer=activesheet.range("A1:Z99")
For Each rngOshiete in rngAnswer
If rngOshiete.Value Like "*書き方を示してください*" Then
rngOshiete.Value= "書き方教えろや"
End if
Next
End Sub
149 :
デフォルトの名無しさん :2007/10/08(月) 08:56:22
Excelのセルにコマンドボタンを貼り付けたセルをコピーしたときに コマンドボタンをも貼り付けるにはどうすればいいのでしょうか? 動的にコマンドボタンを作成する方法でもいいのですが・・・
151 :
デフォルトの名無しさん :2007/10/08(月) 09:14:20
>>147 ありがとう御座います。
Dim R As Range
Set R=Worksheets("Sheet1").Range("A1:C10")
an=Application.WorksheetFunction.Min(R)
こんな感じで使うことはできるのですが
配列の値をいったんシートに入れないといけないのでしょうか?
シートを使用せずにRange変数に入れるにはどうしたらよいのでしょうか?
152 :
デフォルトの名無しさん :2007/10/08(月) 09:35:23
>>150 調べたのですが・・・ユーザフォームでなくセルに配置してあるボタンを
コピーできればいいのですが。現状できないようですし、
できないのならセルコピー後なんらかのマクロで指定されたボタンとボタンをクリックされた
ときのプロシージャを動的に作成できないのかと探していましたが
そういった処理の例はなかなか無いようで・・・
>>151 そのRangeはあくまでも参照なのでメモリ上に作るって用途じゃない
ただRangeのValueは2次元配列と互換できるんで、2次元配列で処理して一括代入が可能
こんな感じで
Dim objRange as Range
Redim varArray(9,2) 'Y,Xの形式で2次元配列を宣言
(適当に配列を初期化)
With ThisWorkbook.Worksheets("Sheet1")
Set objRange=.Range(.Cells(1,1),.Cells(10,3))
objRange.Value=varArray
>>152 >そういった処理の例はなかなか無いようで・・・
検索リンク先を本当に見たのかね?
OLEObjectsとかモロで出てくるんだがね
154 :
139 :2007/10/08(月) 12:38:42
>>144 さん
パート2で、10秒おきに行を挿入するマクロを
書いていただいた方ですか?あの時は、ホント助かりました。
先月までバリバリ使ってました。ありがとうございました。
ちょっとは勉強しようと思ってるのですが、
数字の処理に追われて、全然スキルがあがってません。
教えて君ですみません。
155 :
137 :2007/10/08(月) 23:13:13
>>153 ありがとう御座いました。
範囲指定が必要なワークシート関数が使用できるようになりました。
objRange.Value=varArray
のようにコードを書くとシート上に配列の値が入ってしまうようです。
ワークシート関数の範囲指定をVBAのコード内で完結することはできないのかな。
もうやだ・・・
Function getrank(ByVal idx As Long, arrayx As Variant)
getrank = 1
For i = 0 To UBound(arrayx)
If arrayx(i) > arrayx(idx) Then getrank = getrank + 1
Next
End Function
>>137 のレス行数の半分以下でできた
列に書かれた文字を、1度出てきたら他を除いて ListboxのListに書き出す書き方ってどうするんですか? あああ あああ いいい いいい えええ −−−> えええ あああ おおお いいい おおお なかなか、うまく除けないです。
collectionでも使え
Select Distinctでも使え
>>159 ちょっと難しそうですが、おもしろそうです。
>>160 おおー、ありがとうございます。
早いレスありがとうございます。
>>159 collectionを使って、重複にエラーでできました。
ありがとうございました。
シートの中で一番右下にあるセルのアドレスを抜き出すことって可能ですか?
可能です
165 :
デフォルトの名無しさん :2007/10/10(水) 04:38:19
お前らVBAをどうやって学んだのですか? またそのきっかけは?
166 :
デフォルトの名無しさん :2007/10/10(水) 08:13:48
本やネットを調べた 必要に迫られて
ヘルプとネットで調べた マクロの記録を弄ってみたら簡単そうで便利そうだったから(事実、簡単で便利だし)
グラフやPivotウィザードの作るマクロは意味不明
170 :
デフォルトの名無しさん :2007/10/10(水) 12:20:17
確に訳ワカメ 集計をピボットにやらそうと思ったけど、意味不明すぎて 結局SQLに逃げた
グラフは初めエラーばっかりでわけわからんかったけど 慣れたら簡単だった
エクセルだと セルの選択は cells(),range(),activecell 移動は cells(x+1,1),activecell.offset() じゃないですか ところで、ワードだと 行の選択や、行の移動の方法は何に該当するでしょうか
わーどうしようもない
彡 ビュウウウ… 彡 彡 .∧ ∧ ヾ(,,゚Д゚),) 人つゝ 人,, Yノ人 ノ ノノゞ⌒〜ゞ . ノ /ミ|\、 ノノ ( 彡 `⌒ .U~U`ヾ 丿
あるセルに入った数値を整数か小数点で色分けしたいのですが(100と100.53みたいな感じ) どういったアルゴリズムで判断すればいいでしょうか select caseとセルの色つけは大丈夫です プログラムの最初に戻るときは、変数の前に飛ばした方が無難ですか それとも、一度、変数を宣言したら大丈夫なものなのでしょうか sub sample() start: dim i as integer
検索条件で「〜と一致しないセル」というのはどうすればいいでしょうか。 例えばA1:W100までに「a,b,c,それ以外」のデータが入っているか空白か、の場合 For Each X In Range("A1:W100") If not X = a and not X = b and not X = c and not X = "" Then 処理 End If Next だと全セルを見に行くので、範囲が広がると時間がかかりそうな気がします。 Findメソッドのような形で不一致条件で検索して、またそこから次を検索して、ということはできませんか。
> Findメソッドのような形で不一致条件で検索して、またそこから次を検索して、ということはできませんか。
それは出来る出来ないではなく「作る」ものだよ。その為のVBA。
時間短縮なら二次元配列に値を取得してからやればかなり速度アップするし
a,b,cではなく"a","b","c"ならlike演算子が使えるし
複数条件使う場合はandで繋げるよりネストした方が速い
ttp://officetanaka.net/excel/vba/speed/s11.htm のように配列使った検索はFindメソッドより遙かに早いくらいなんで、
速度求めるなら組み込みメソッドに拘るなんてバカらしい
>複数条件使う場合はandで繋げるよりネストした方が速い Ifの条件節が2つだけでも多数でもAndよりネストのほうが早いんですか? 今まで勝手なイメージで条件のネストや繰り返しより1つのメソッドで済むものは済ませたほうが 早いのかと思っていたので勉強になりました、ありがとうございます。
182 :
デフォルトの名無しさん :2007/10/12(金) 03:33:27
おまえらVBA勉強してよかった事ある?
ないよ
184 :
exc :2007/10/12(金) 06:46:22
>>182 VBA楽しくて好きなんですけど仕事ではほとんど使ったことないですね。
データをリスト形式で並べておいてソート,フィルタ,ピボットテーブルレポ
ートでほぼ終わりです。
さびしい。もっと使いたい!
ビジネス用途でなんかおもしろい使い方ないですか?みなさん。
185 :
exc :2007/10/12(金) 07:10:41
私がVBAを仕事で利用した例 品質管理のため毎回5個ずつ抜取検査する商品があり, 測定データが次のような形式で入力されていた。 測定日 商品 値1 値2 値3 値4 値5 10/1 ABC 32 31 34 33 31 10/2 XYZ 45 47 43 42 45 10/3 ABC 35 32 34 31 31 ・ ・ ・ 測定値の度数分布を測定日別,商品別にピボットテーブル レポートで集計したいがこのままの形式ではピボットテー ブルレポートが使えない。 (続く)
186 :
exc :2007/10/12(金) 07:11:31
(
>>185 の続き)
そのため
データをVBAで次のように整形した。
測定日 商品 測定番号 値 度数
10/1 ABC 1 32 1
10/1 ABC 2 31 1
10/1 ABC 3 34 1
10/1 ABC 4 33 1
10/1 ABC 5 31 1
10/2 XYZ 1 45 1
・
・
・
これで無事にピボットテーブルレポートが使えた。
以上。
187 :
デフォルトの名無しさん :2007/10/12(金) 07:19:21
188 :
exc :2007/10/12(金) 08:07:15
>>187 ごめん。確かにこのスレッドの趣旨とは違うかも。
でも誘導先も…。
個人用EXCEL活用法
1 :名無しさん@そうだ選挙にいこう :2001/02/17(土) 16:11
実験結果をただグラフ化するが為にEXCELを購入しました。
今の時点ではそれ以外に使い道が無く、何だか勿体無いように感じます。
ところで皆さんは、仕事以外の日常生活に擱いてどのようにEXCELを活用していますか?
191 :
exc :2007/10/12(金) 08:37:44
>>190 僕も悪いけど
>>187 もあわて者だねってことです。
ごめんなさい。この話題やめましょう。さよなら。
193 :
デフォルトの名無しさん :2007/10/12(金) 14:33:53
VBAの練習をしています。 FormにTextBox×1、ComboBox×3を配置して、 TextBoxに名前を、ComboBoxにはそれぞれ生年・月・日を入力できるようにしました。 入力できますが、重複防止がまだできません。 生年月日の入力時に(Changeイベントで)、名前の重複を検索し、 重複があれば生年月日の重複検索をして、 そこでも重複があれば同一人物として入力不可にしようと思います。 重複の検索の仕方がわからないのですが、 御教示お願いします。
同姓同名、同生年月日の別人の存在に考慮しなくていなら 単純に検索すればいいだけじゃん 入力された名前か生年月日で検索して、一致が有ればもう一方も一致するかをチェック 両方一致なら重複扱い、もう一方が一致しなければFindNext Find、FindNextの使い方はヘルプ見てね
195 :
193 :2007/10/12(金) 18:52:20
>>194 ありがとうございます。
帰ったら早速やってみます。
>>186 どんなVBA書いたのか知らないけど
そういう整形はUNIONクエリ一行で出来てしまう
Excelで?
198 :
exc :2007/10/12(金) 20:48:03
>>196 ほんとだ!あの時は全然思いつかなかったからVBAでこつこつやっちゃった。
しかしますますVBA使う場面がなくなるな。
>>197 196じゃないけど、最近、
Accessなどを使わずに
Excelのリスト形式名前付き範囲に対して
ExcelからADO経由でクエリーを実行するのがマイブーム
一度クエリー発行の仕組みを作れば後が楽なので
条件が複雑になればなるほど便利。
というか普通の使い方だと思う。
201 :
デフォルトの名無しさん :2007/10/15(月) 13:02:49
Formを開いた時に常に最大表示になるようにしたいのですが できません。 標準モジュールに Sub auto_open() Application.DisplayFullScreen = true UserForm1.Show End Sub としたのですが… Application.DisplayFullScreen = true の他に Application.WindowState = xlMaximized も試してみましたが駄目でした。 どこが間違っているのでしょうか?
202 :
exc :2007/10/15(月) 21:53:24
>>199 ぜひもっと詳しく教えて下さい。
参考になるサイトとかないですか。
>>200 の本を読むといいのかな?
VBAでEXEファイルを作る方法がわかりません どなたか教えてください
>>203 Open "hoge.exe" For Binary As #1
>>204 すみません・・・本当に初心者でどういうことかわかりません・・・・
ユーザーフォームの出力とかやってみたんですが.frmと.frxというファイルしか出てこなくて何をすればいいのかさっぱり
ネタじゃなしに、マジにEXEを作れると思ってんの?
207 :
デフォルトの名無しさん :2007/10/17(水) 08:46:51
Excel2003でスライダーコントロールを追加して操作できるようにしたいのですが VB上でActiveSheet.OLEObjects.Add ClassType:="MSComctlLib.Slider.2" としても、ツールバーから直接追加しても、スライダーが動かせません デザインモードで形を変えたり位置を移動すると動かせるようになるのですが プログラム上で同様の操作をしても動かせないときが多いです おそらく標準以外のコントロールを使用しているためだと思うのですが どうやったら安定して動かせるようになるでしょうか?
208 :
デフォルトの名無しさん :2007/10/17(水) 16:32:50
EXE作ることできないんですか? ということは作ったプログラムを使うためにはいちいちエクセルを起動しなきゃいけないんですか・・・
なんか、VBとVBAを混同してる人な予感
>>110 すごい遅レスだけど、@はSet行で実際にNewされてオブジェクトが生成されるけど、
Aはオブジェクトはその行では生成されないという違いがある。
つまりDimではnewされないってこと。
オブジェクトを10個作るつもりで
dim dic as new dictionary
for i = 1 to 10
dim obj as new myclass
dic.add key, obj
next
とやると実際にはobjは1個しかできないからね。
最後に質問していいでしょうか? エクセルのVBAのフォームを使えば簡単にボタン配置などができて便利なんですがEXEファイルに変換 できないのであれば、やはりCなどで一からつくり直さなくてはいけないんでしょうか。また、VBを使えば VBAで作ったフォームをEXEに変換できるのですか。
>>212 プログラムの互換性はあるけど
VBでエクセルを直接操作できるわけじゃないから
そんなこと考えるだけ無駄
>>213 ようするにVBAは悪魔でもエクセルの一機能で独立させることはできないということですね。
ありがとうございました
>>214 VBA は Visual Basic for Application の略 OK? ってもう見てないか w
Activesheet.Shape.Nodes(1)とかいろんなプロパティが載っているVBの本って無いですか? ヘルプとネットで調べるのが効率悪くて。
>>210 というかそれは2回目以降のDimが無視されてるだけ
ともとれるね
>>213 >VBでエクセルを直接操作できるわけじゃないから
できるよ
221 :
216 :2007/10/17(水) 23:03:56
>>200 知っているのがありましたら教えてください。
222 :
216 :2007/10/17(水) 23:04:28
スマソ
>>220 知っているのがありましたら教えてください。
223 :
デフォルトの名無しさん :2007/10/17(水) 23:16:39
>200でいいんじゃね?
>>216 ヘルプをプリントアウトすればいんじゃね
自分なりに工夫して纏めて
225 :
デフォルトの名無しさん :2007/10/18(木) 04:09:55
Excel2002のVBAからOracleのストアドプロシージャ(PL/SQL)を呼び出したいのですが 呼び出し部分と戻り値の受け方のサンプルソースは無いでしょうか? ODBC経由のSQLだと投げたきり返ってきませんが PL/SQLだと1,2分で返って来るので、何とか使いたいのです。 よろしくお願いします><
>>217 いえ、Dimはあくまでも宣言文であって、最初のアクセス時に実際にNewされるんです。
Sub Foo()
Dim obj as new myclass
Exit Sub
とすると、Newされません。
まぁこれを「無視されている」というならそのとおりですが・・・
dim文はCなどで言うところの「定義」ではなくて「宣言」ということだな
つか、今ヘルプ見たらちゃんと書かれてるじゃん >New >省略可能です。このキーワードを指定すると、オブジェクトを暗黙的に作成できます。 >オブジェクト変数を宣言するときにキーワード New を指定した場合は、オブジェクトを >最初に参照したときにオブジェクトの新しいインスタンスが作成されるので、Set ステー >トメントを使ってオブジェクトへの参照を代入する必要はありません。
やっぱりヘルプが一番だな。
うむ
231 :
デフォルトの名無しさん :2007/10/18(木) 15:09:52
とはいえ良い勉強になったな
Sub 今日の日付() Cells(1, 2).Value = Date ActiveSheet.Name = Format(Date, "yyyymmdd") End Sub このような感じでボタンをポチっと押すと、 ・指定したセルに日付を入力 ・現在のシート名を20071018というような名前にしています これを1日に2回目が必要になったときに(データが重複する時) ・指定したセルに日付を入力 ・その真下のセルに「2」というデータを入力 ・現在のシート名を「20071018-2」というように通し番号を入力 したいです。 一日に3回目もたまに必要になりますが、 どのように行えばいいでしょうか?
Sub 今日の日付(ByVal SerNum As Long) Cells(1, 2).Value = Date Cells(2, 2).Value = SerNum ActiveSheet.Name = Format(Date, "yyyymmdd") & "-" & Cstr(SerNum) End Sub
ちょっと相談させてください。 レコードが数万、列がレコードによって可変(2〜30くらい)のカンマ区切りのCSVファイルがあって、 その第一列目にだけ特定文字列の置換処理を、出来るだけ高速に行いたいのです。 とりあえず思いつくのは二次元配列に入れて置き換えてそのままCSVでまた書き出す、というもので Sub csvRead() '書き込みが長くなるので宣言は省略 ' 配列の上限設定 LastCol = 0 Do Until ffile.AtEndOfStream DataLine = Split(ffile.Readline, ",") If LastCol < UBound(DataLine) Then LastCol = UBound(DataLine) Loop LastRow = ffile.Line - 1 ffile.Close ReDim TmpData(LastRow, LastCol)
' 2次元配列に格納 Set ffile = fso.OpenTextFile(csvName, ForReading) R = 0 Do Until ffile.AtEndOfStream DataLine = Split(ffile.Readline, ",") For C = 0 To UBound(DataLine) TmpData(R, C) = DataLine(C) Next R = R + 1 Loop ffile.Close '以降TmpData(1〜最後まで, 1)に対して置換、CSVを書き出し End Sub 帰宅してしまってテストしていないのですが、 漠然とこんな感じかと思ったのですがもっと速く処理できる方法はありませんか? CSVエディタや置換専門のフリーソフトが一番速いとは思うのですがそれはナシとさせてください。
236 :
232 :2007/10/18(木) 20:46:01
>>233 「引数は省略できません」とエラーがでました。
詳しく状況を書くと、テンプレートのシートがあって、
それを同じブックにコピーします。
そのシート名を日付にしているので、
右のシート名が同じなら、YYYYMMDD-2となってほしいです。
237 :
デフォルトの名無しさん :2007/10/18(木) 23:20:51
すいません、質問があります。 AccessVBAで、エクセルVBAのマクロを使用したいのですが上手くいきません。 どちらも2003を使用しています。 アクセス側で「Application.Run "C:\○○.xls!マクロ名" 」と呼び出しているの ですが、「マクロが見つかりません」とダイアログがでます。 マクロの指定方法が良くないのでしょうか? 最近始めた初心者で、しょうもない質問で申し訳ないです。
数万レコードのCSVに一列だけとはいえ置換をかけるならセル上でやるより 配列の中でやったほうが速いと思うが、配列からCSVへの保存ってのは時間かかりそうだ。 一発で出来る方法あったっけ、1区切りごとに書き出すことになるんじゃないかな。 かといってワークシートに貼り付けて保存すると文字列が""囲いになったりするし。
・CSVファイルを開くもしくは配列に格納 ・置換 ・CSVファイルに保存 それぞれのステップで最速になるようにすればいい。 第一のステップはセル上に開なら実は書式を文字列にしてテキストとして 普通に開くのが一番速く配列に格納してから開くのは2番目に速いが、 セル上に開かないで格納するだけなら多分大差ないと思う。置換は比較したことないけど多分配列の中でやるのが最速だろう。 問題は出力だが、二次元配列からCSVに保存ってどうするんだろうな。 列データごとにカンマを挟んでString変数に追記して1レコードずつ書き出して .TXTで保存してから拡張子をCSVに変えれば""も付かないと思うが、これは遅そうだな。
> 二次元配列からCSVに保存ってどうするんだろうな ADOかDAOってのが通例
ADOかDAOか、全然使ったことないからわからんな。
ただ
>>234 FSOを使うより普通にOPENメソッド使った方が配列への格納時間は短くなる。
243 :
デフォルトの名無しさん :2007/10/20(土) 00:56:12
>>241 ネットでいろいろ調べてのですが、
呼び方はこれでは駄目なのでしょうか?
Dim objXL As New Excel.Application
Const f_Name = "C:\test1.xls"
Const m_Name = "test_mc" 'マクロ名
・
・
mc = objXL.Application.Run(f_Name & "!" & m_Name, "Sheet1")
マクロは標準モジュールにあります。
何故かVBEのツールボックスが選択できなくなってしまいました (白抜きになっている) どう対処したらよいでしょうか
一定の範囲内にある数値の中で、最大値を持つセルの行番号を求めたいのですが、 IF文を使って比較と代入を繰り返す(それまでの最大値より大きい値を持つセルの 場合に行番号をその都度更新していく)のではない方法はありますか?
>>245 RowとMAX組み合わせりゃ関数でできるだろ
worksheetfunction.max(range("a1:c5")) みたいな感じ
あ、行番号か。 range("a1:c5").find(worksheetfunction.max(range("a1:c5"))).row
249 :
245 :2007/10/22(月) 17:35:53
>>246 ,247=248
即レスありがとうございます!
worksheetfunction.max(range("a1:c5")).row
あたりまでは何とかたどり着いていたんですけど、その先で行き詰まっていました…
おかげさまで解決できました!!!
ありがとうございました!!!!!
>>244 俺もなった
ついでにVBE上のIMEも死んだ
仕方がないのでExcel全部再起動
これで直った
251 :
デフォルトの名無しさん :2007/10/25(木) 14:34:47
Excel の質問なんですが、どこに訊けばよいかわからないので、 一旦ここでうかがいます。 環境:Windows XP、Excel 2000(両方とも日本語環境) Excel の印刷中に出る「印刷中」ダイアログでは、 通常そのメッセージが以下のようになるため それを想定してプログラムを作成しました。 現在 '[文書名.xls]' を [プリンタ名] on Nexx: で印刷中です。 ところが、あるユーザの環境で動かないため調べていたら 現在 '[文書名.xls]' を Nexx: の [プリンタ名] で印刷中です。 と表示されていました。 この3行目の表示が想定外であるためプログラムが動作しません。 これに対して個別対応は可能なのですが、 今後他のケースが出て来ないとも限りません。 そこで質問なのですが、 この「印刷中」ダイアログの表記を変更する方法があるのでしょうか? 方法等、ご存知の方いらっしゃいましたらよろしくお願いいたします。
>>251 何がしたいのか分からないけど、考え方自体に問題がある気が。
ダイアログを変えるのじゃなくて
ダイアログの文字列を取得できるのなら
取得文字列をうまく利用する方向で
application.ActivePrinter
でプリンタ名は取得できるわけだし
あとは正規表現使うなり、InStr使うなりでなんとかなる気が。
253 :
デフォルトの名無しさん :2007/10/25(木) 19:13:55
基本じゃね?
255 :
デフォルトの名無しさん :2007/10/25(木) 20:24:46
基本だったのか。。。
>>253 どのような状況でも変数の値を保持したい場合は、以下の方法を使用します。
? Excel の場合 非表示にしたワークシートに値を記述します。
? Word の場合 文書変数 (Variable オブジェクト) を利用します。
? PowerPoint の場合 非表示スライドなどに値を記述します。
そりゃそうだろうけどさ…
>原因 >この動作は、VBA の仕様に基づく制限です。 VBAのPublic変数はPublic変数ではないとゆうことだな
visual basicでも > 押して □ 押せば public変数だろうが消えるだろ それのことだよ
>>257 ハズレ
Visual Basicで作ったアプリだって、アプリを一度終了して再度起動したら変数の値は保持されてないだろ
VBAの場合、「実行可能状態=編集可能状態」なので、実行後は編集可能状態にになるためアプリを一度終了してるのと同じ
まぁ大抵は「編集可能状態」では保持され「編集状態」になると破棄されるんだけどね
>>258 も言ってるとおりで、IDE上の実行とかインタプリタ型マクロとか、編集可能な状態で実行されてるものは、ほとんどこういう仕様だよ
普通の実行ファイルとほぼ同じで、終了したら値は保持されない(保持が保証されない)けど
普通の実行ファイルと同じで、実行中は値が保持され、Public変数はPublic変数として正常に機能する
ただ、この「実行中」というのは当然ながら「VBAを含むシートを開いてる間」ではなく「マクロの実行中」なだけ
その辺解ってれば「VBAのPublic変数はPublic変数ではない」なんて勘違いは発生しない
>>253 むしろ終了後も値が残ってしまう可能性がある事を初めて知った。
毎回必ず初期化されるものだと思っているとハマリそう。
初期化は明示する癖をつけた方が良いってことだ
262 :
デフォルトの名無しさん :2007/10/26(金) 19:45:38
Public変数はグローバルな変数ではないとゆうことだな
また勘違いした奴が…
VBAの中から任意の範囲選択を促すダイアログを出すにはどうすればよいのでしょう? グラフウィザードやPivotウィザードとかで範囲選択するときに出てくるアレです
InputBoxじゃね
はぁ?
Refedit
すいません。 教えて頂きたいです。 学校の課題なのですが・・・ 「三山崩し」をユーザーフォームを利用し、ゲームとして楽しめるようにしなさい。 と出ました。 どなたか作って下さいませんか? お願いします。
>>269 まずはお前がどれ程の努力をしたのか見てからだ。
ここはプログラムを提供してもらう場じゃない。
それって四十八手の一種か?
272 :
257 :2007/10/27(土) 18:23:43
>教えて頂きたいです。 と >どなたか作って下さいませんか? わろす
学校の課題で、VBAにユーザーフォームか… そういう時代なんだなあ。
俺Office持ってません
どうせ専学だろ
OpenOfficeのCalcのスクリプトの質問はここでいいですか?
当然ながらダメです
279 :
デフォルトの名無しさん :2007/10/27(土) 22:18:37
鼬害←最近読み方を覚えた
280 :
デフォルトの名無しさん :2007/10/28(日) 00:35:06
excelのvbaって何で使うんだろう?
日本語で(r
winXP excel2003 Sheets("").select という文で、()の中に入れるシート名を、現在アクティブになっているシートを入れたいです。 どうすればいいでしょうか? この文じゃなくてもアクティブシート名をセレクトできたら構わないです。
284 :
デフォルトの名無しさん :2007/10/28(日) 09:30:02
>>283 お前、自分では少しも調べてないだろ。
最低でも”アクティブシート 取得”ぐらいでググれよ、クズ。
285 :
デフォルトの名無しさん :2007/10/28(日) 09:34:47
>>283 dim sht as String
sht = ActiveSheet.Name
MsgBox sht
というかアクティブシートって既にセレクトされてないか?
287 :
デフォルトの名無しさん :2007/10/28(日) 13:17:11
simatta! tsuridattanoka...
>>286 セレクトされてるよ
でもアクティブシートだけがセレクトされてるとは限らない
283がどう使うのかは解らないが、例えば複数シート選択状態から
非アクティブな選択シートを外してアクティブシートのみの選択にしたい場合は
ActiveSheet.Select
という処理を行う
通常は「アクティブシート=セレクトされてるシート」だが
こういった例外も想定出来るようにならないと良いプログラムは書けないぞ
>>288 まあ、この場合は元質問が
>この文じゃなくてもアクティブシート名をセレクトできたら構わないです。
だからアクティブシートはセレクトされていますでOKな気もするが。
ところで複数選択時の.Activateと.Selectでの
複数選択解除の挙動が
ActiveSheetに対する場合とActiveCellに対する場合で
逆なのはちょっと面白いと思った。
というか、ActiveとSelectを使用している時点で良いプログラムとは言えない
そうでもないか
Copy と Paste 多用してるけどw
293 :
sage :2007/10/29(月) 16:52:09
すいません。VBEditorについて聞きたいのですが・・。 プロジェクトウィンドウやプロパティウィンドウ、コードウィンドウを 分離させて使用していたものを初期状態(ドッキング状態)に戻すには どうすればいいのでしょうか・・。
>>293 「プロパティ」とか「イミディエイト」とか表示されている
各ウィンドウのタイトルをダブルクリック。
295 :
デフォルトの名無しさん :2007/10/30(火) 10:17:17
VB6でいう、CommonDialogを実現するにはどうしたらいいのですか。 開発側 Windows XP Pro SP2 Office XP 利用者側 WindowsXP, 2000 Offece XP, 2003 開発側で作成したワークブックだけを利用者に渡して、設定とかせずにすぐに利用できるようにしたい。 ワークシート上のある範囲のセル値を、作業ファイルとしてcsvで一時的に保存場所を指定して保存させたい。 保存場所を指定して、作業ファイルを選択してワークシート上に読込ませたい。 といったものを考えています。
296 :
295 :2007/10/30(火) 10:30:54
書き忘れ 諸般の事情でフォームは使わずに、ワークシート上のボタンにコマンドを割付ける。 フォームであればコントロールを追加すればいいんでしょうけど。
297 :
sage :2007/10/30(火) 11:21:35
>>294 アドバイスありがとうございます。
ダブルクリックでプロジェクトウィンドウとプロパティウィンドウは
ドッキングするのですが、コードウィンドウだけがドッキングしてくれません。
こういうものでしょうか?
ドッキングしたプロジェクトウィンドウとプロパティウィンドウがVBEの枠からはみ出るのが
気になるんですが・・
>>295 GetOpenFilename でサエコれ
特定のシート以外からは使用できないユーザー定義のワークシート関数は作れないの?
300 :
デフォルトの名無しさん :2007/10/30(火) 23:25:54
作れる
時刻の入ってるセルの値を「表示通りに」取得するにはどうすればよいのでしょうか。 セルに「12:00:00」って書いて.valueなり.formulaR1C1なりで読み出すと 勝手に0.5(だっけ?)になってしまって非常に困ります。 文字列の"12:00:00"として取得したいです。 書式を文字列するのは訳あってできません。
型変換関数って知ってるか?
Format(.Value, .NumberFormatLocal)
あれ? .Textじゃダメなんだっけ?
あれ?Textは「######」とか返してくるの知らないの?
それでも表示通り
画面表示と印刷の結果も違ったりするよね。
>>306 おぉ試したら確かに#が返ってきた
非表示だと""が返るのな
勉強になるな〜
ついでに、[h]:mmのときでも
正しく取得できる方法をお願い
なにそのコンドームに穴があいてても避妊できる方法をお願いしてる感じw
図々しい教えて野郎ばっか来るのな
312 :
VBA初心者 :2007/11/01(木) 16:23:19
シートdata2を変数Mywd2に代入しまたシートdata3を変数Mywd3に代入する。 その上でメッセージボックスにそれぞれのシートの名前を表示させる。 sub macro1() dim mywd2 as worksheet dim mywd3 as worksheet dim res1 as variant dim res2 as string set mywd2 = worksheets("data2") set mywd3 = worksheets("data3") msgbox mywd2.name msgbox mywd3.name やってみたのですが、これで大丈夫でしょうか?
大丈夫って何が?
314 :
VBA初心者 :2007/11/01(木) 17:09:46
なんで聞く前に試さないの?
操作間違えると、PCが爆発するとでも思ってたり w
よく読め。 やってみたと書いてるじゃないか。
適切とは言えないが間違ってはいない
得に問題はないから、この先へは自分で行き着こう
そもそも
>>312 は条件に関係なく「最適とは言えない」と断定できるが
「なら何が最適か?」となるといろんな条件が関係してくるので
どういう条件で何がしたいのか(名前を表示するだけで終わりではないだろ)を
ほとんど書いてない状況では答えようも無いしね
まあ、後出しでいろいろ書かれてもウザいだけなので後は自分で頑張ろう
別に目的があるんじゃなくて単なる練習なんだろ シート名決め打ちだったらわざわざ取得する意味無いw
320 :
デフォルトの名無しさん :2007/11/01(木) 23:01:46
ぜんぜん関係なくて悪いけど、 俺最近VBA触り始めたんだが意外となんでもできるのな。 馬鹿にしてて悪かった。
俺はむしろVBA無しの素のExcelを最近見直した 意外となんでもできるのな VBA使いだすと歯止めが利かなくなってどんどんExcelを使う意味が薄くなる気がする
↑関数で出来ることをわざわざVBAでやってた俺だ w
323 :
デフォルトの名無しさん :2007/11/02(金) 09:16:48
関数とVBAと、どこでやめるか、みたいなところが難しいと思う。 自分で使うだけのブックならいいけど、後々引継いでもらうような奴だと特に。
324 :
デフォルトの名無しさん :2007/11/02(金) 11:07:01
2003エクセル 使ってます。 同じ作業の繰り返しを頼まれて困ってます。 02375290 のようにあらかじめ入力してあるせるセルに ↑ ↑ TKDME D と入力したいですがマクロでできますか? これをコピペで永遠にやっています。 VBA神さま助けて下さい。
325 :
デフォルトの名無しさん :2007/11/02(金) 11:10:28
うわ、行がずれてた。 文頭にTKDME 0237★5290 ★にDと入れたいという意味です。
変換前の文字列と、変換後の文字列を、スペースを考慮して正確に書け。 変換に複数のルールがあるなら、それも書いとけ。
対象のセル範囲を選択して、次のマクロを実行。 Sub foo() Dim c As Range For Each c In Selection c.Value = "TKDME" & Left$(c.Value, 4) & "D" & Right$(c.Value, 4) Next End Sub
328 :
デフォルトの名無しさん :2007/11/02(金) 11:21:34
>>326 本当にごめんなさい、マクロは本で読んだことしかないのですが
繰り返し作業ができると書いてあったので自力で調べましたがうまく
いかなかったです。
変換前 02375290
変換後 TKDME0237D5290
です。
>>327 ありがとうございます。一度やってみます。!!
329 :
デフォルトの名無しさん :2007/11/02(金) 11:25:11
>>327 様
できました。ありがとうございました。
昼までに作業が終わりそうです。
それこそVBAじゃなくてワークシート関数で出来るだろ・・・
あっ「EXCELは得意です 自分なんでもできますよ」と、経歴詐称して 高単価で潜り込んだ前職テレアポの派遣社員のような気がする。
="TKDME"&LEFT(A1,4)&"D"&RIGHT(A1,4) こうかな これくらいならこっちのほうが楽だけど普通はマクロでやるわな
VBAをマクロの区別が付いてなさそうなやつが「普通」とか言ってもなぁ
普通は”マクロ”でやるよ
今時の流れだと、極力シート関数を使うほうがOpenOfficeでも使えていいと思うが。 # しかし、:,; の扱いが違っているからたまにめんどくさい……
ワークシート関数だと、
>>327 と同じことはできないわけだが。
具体的に何が出来ない? んな再利用もしにくいしょうもないコードをいちいちVBAで記述しろ、と? ワークシート関数で出来ることはワークシート関数でやるのがEXCELの基本でしょ ただ単に「おれって出来るんだぜ〜」みたいな痛い自慢をしたいならともかく、生産性に 大きな違いがないなら、汎用性やオペレーションに気を使うのが「普通」の会社人ってもんでそ
>>327 A1:B10に文字列が設定されてたとして、ワークシート関数だとどう操作するのさ?
ワークシート関数の方が「いちいち」感があるのは俺だけか? それとも、何か痕跡を残さず実行できる、アクロバティックな方法があるのだろうか。
>>337 普通に考えて、そのセル自身をワークシート関数の結果で置き換えることが、1stepではできない。
>338
C1にワークシート関数打ち込んでD10までコピペしろよ
>>341 だからな、毎回やるオペレーションなら、んなしょうもないコードじゃなくて、
ユーザー定義関数を作るとか、VBSだし、そもそも1回こっきりなら一番速いのは
正規表現使えるエディタで置換だ
んで、定常オペレーションでも単なるテキストオペレーションなら、そこはEXCELにこだわらずに、
VBSでD&Dとか考えるべき
VBAに妄執を抱いて他の選択肢が頭にない時点で、おみゃあはセンスが欠如しとる
ちと推敲足らずに意味不明のくだりがあった スマソ
>>342 > >338
> C1にワークシート関数打ち込んでD10までコピペしろよ
それだと
>>327 とは違う結果になるよね。
>
>>341 > だからな、毎回やるオペレーションなら、んなしょうもないコードじゃなくて、
> ユーザー定義関数を作るとか、VBSだし、そもそも1回こっきりなら一番速いのは
> 正規表現使えるエディタで置換だ
> んで、定常オペレーションでも単なるテキストオペレーションなら、そこはEXCELにこだわらずに、
> VBSでD&Dとか考えるべき
> VBAに妄執を抱いて他の選択肢が頭にない時点で、おみゃあはセンスが欠如しとる
どう考えても、327みたいなかき捨てのVBAマクロを書いた方が早いし簡単。
>>327 程度のマクロが、何かこいつの劣等感を刺激したんだろうか
あかんな VBAとマクロの区別が曖昧なバカに何を言っても無駄だとはよく分かった
「おれって出来るんだぜ〜」みたいな痛い自慢をしたいのは、
>>337 =342のように見えるのだが。
>>337 使い捨てマクロは全否定ですか、そうですか。
一行野郎も全否定なんでしょうね。
VBAとマクロって区別するようなものではないだろ
だって同じ定義だもん
VBAは言語の種類。マクロは、それで書いたプログラム。 Excel4のもマクロです。(使う人はもういないだろうけど)
>>323 も書いてるけど
自分だけが使うようなものじゃないなら、極力VBAを使わない覚悟が必要だよね。
なんでもできるもん!系統の駄目な子って、まずドキュメントを残そうとしないし。
シート関数を駆使したセルを置いておく香具師も、必ずしもドキュメントを残さないがな。
子供の言い訳みたいなこと書かないで良いから な?
今回のケースは、どう見てもマクロの方が楽だし目的にも合ってる。 何で粘着するのかわからん。
どうでもいいけど、ごたくは
>>327 と同等のことをワークシート関数で書いてから言え
Unix文化に触れたら、文句言いまくりそうだなw
うわ!どう見てもテキストエディタで置換するだけで済む話をまだ引っ張ってるよw
間抜けすぎだよ
>>356
なんで粘着してんだこいつ
エディタ使うくらいだったら、ワークシート関数の方がまだましだな。
まさかマクロに劣等感もたれるとは思わなかった。
連投するほど悔しがらなくても良いんだぞぉ 悔しがるのは「マクロマクロ」連呼しちゃう自分の間抜けさに対してになー 一つのことにこだわるのは正しいように見えるけど、他の選択肢を考えられない時点で脳が硬化してる 自覚できてよかったな(^ω^)
かわいそうだな書くのに1分もかからないようなマクロ見て 怯えてるなんて
>>364 ふつー、最も簡単な解決法を示せば、それで終わりだろ。
で、それがマクロだったと。
もう勝ち逃げさせてやろうぜ。 相手にしても利益なし。
369 :
デフォルトの名無しさん :2007/11/02(金) 23:41:51
VBAの唯一の利点はエクセルのインストールされてないPCなんてほとんどないことぐらいか。 出先でも他人のPCでもとりあえずなんとかできるのはけっこう助かる。
シート上のセルの値を変更したいんだろ? VBAマクロがベストマッチというのに異論が出るのが不思議。
多分
>>321 がファビョってたんだと思うけど、ワークシート関数じゃ
>>327 みたいなことはできませんからwww
自分
>>321 だけど騒いでたのは他の人だよ
別に
>>321 はマクロを使うことを否定するつもりで書いたんじゃないし、
この場合マクロを使ったほうが適切だと思う
俺はVBA使ってるとつい VB+出力(たまたまそれがExcelだっただけ)
みたいにしたくなってしまうので、なんとかしないといけないなあと思っただけ
×出力 ○入出力 どうでもいいけど一応
正直スマンかった。
1文字変数使うやつは駄目
>>375 悔しいのはわかるがそんな短絡的なことでどうする?
377 :
375 :2007/11/03(土) 02:56:53
いや、残念ながら君の想定する人物と俺は違う また無差別認定か 前々から同じこと書いてるだろに 馬鹿なやつだな 自分から心に余裕のないのを晒してどうするのさ ま、それは置いてとにかく1文字変数はやめろ コーディング規約を考えていない それがVBA系にゴロゴロいる駄目なやつの共通点だ
目的はコーディングじゃないから仕方ないだろ。 うごけばいい 規約なんて勉強しなくても うごけばいい
iも駄目かね
悔し紛れのがまだましで なんの脈略もなく一文字変数はだめだって それだけって単なるあほだろ
ifのあとのthenは無駄だよな
A1表記を使わないというコーディング規約を定めたがColumnsで断念したことあるにょ!
一文字変数は後から読む側にとっては大変だ 定義しないでVariantで頻繁に使われてるとさらに困難
>>379 ループ変数でも、
実際にはループ自体に添字とか何らかの意味はあるはずだから
そちらを使うほうが分かりやすい。
For文内で汎用ループ変数として使うのはさほど問題ない気もするが
最近はExcelでもIntegerで足りない事が結構ある。とはいえ
Dim i as Long は駄目だな。あくまでInteger限定。
「i」にも、「ただのループ変数だよ。使い捨てだから後から参照しないよ」
程度の暗黙の了解はあるけれど、
型と同様、通じない人(というか無視して組む人)もいるのでお薦めはしない。
>>382 それっぽっちのことで断念するのかよ
全然問題にもならないと思うが
386 :
デフォルトの名無しさん :2007/11/03(土) 13:17:42
>>381 それ考えると、UNIXのシェルスクリプトは医大だよな。
ifの終りはendifじゃなくてfiだよ。
387 :
デフォルトの名無しさん :2007/11/03(土) 14:52:09
>>386 UNIX のシェルスクリプトといえば
[ と ] が演算子だと知ったときに感動しました
>>385 どうやって回避するの?
Columns("A:C")って記法は固定みたいなんだけど
Columns使わなきゃならんの?
>>390 n列おきにセル幅を設定するって部分があって
chrでASCIIコードに増分与えようかと思ったけど、可読性が極度に落ちるのと、
どうせ再利用する機会が多いんで、結局10進to26進関数を組んで回避したことがあったんだ
Columns("A:C").Hogehoge() ↓ Dim r As Range Set r = Union(Columns(1), Columns(2), Columns(3)) r.Hogehoge() だそうな
可読性はようわからん Dim r As Range Dim i As Integer Set r = Columns(2) For i = 5 To 14 Step 3 Set r = Union(r, Columns(i)) Next r.Select With Selection.Interior .ColorIndex = 40 .Pattern = xlSolid End With
395 :
デフォルトの名無しさん :2007/11/03(土) 18:13:57
Unionは知らなかった 勉強になった サンクス!
>>392 こんなんあったのか
Dim I As Integer
For I = 1 To Rng.Areas.Count
Rng.Areas(I).Value = I
Next I
なんか便利そう
変態的解決法もあるね 4列おきに2列の操作するとか With ThisWorkBook.Worksheet(1) For intClm=1 To 16 Step 4 Set rngBuf = .range(.cells(1,intClm),.cells(65536,intClm+1)) '(処理を記述) Set rngBuf=Nothing Next End With
俺メモ Sub hoge() Dim r As Range Dim i, j, k As Integer k = 0 For i = 2 To 8 Step 2 For j = 3 To 9 Step 3 If k = 0 Then Set r = Cells(i, j) k = 1 Else Set r = Union(r, Cells(i, j)) End If Next Next r.Select For i = 1 To r.Areas.Count For j = 1 To r.Areas(i).Areas.Count r.Areas(i).Areas(j).Value = CLng(i - 1) * r.Areas(i).Areas.Count + CLng(j - 1) Next Next End Sub
400
401 :
デフォルトの名無しさん :2007/11/06(火) 14:12:24
ExecuteExcel4Macroを使うことで、Bookを開かずに値を取得することは出来ました。 Bookを開かずに書き込む方法がわかりません。 何かヒントでもあればよろしくお願いします。
>>401 「開かずにできた」というのは、気のせいじゃないか?
403 :
デフォルトの名無しさん :2007/11/06(火) 14:48:06
>>402 タスクバーには表示されなかったんだけどなあ・・・
>>403 どうやってやったんでしょう?教えてください。
405 :
デフォルトの名無しさん :2007/11/06(火) 15:06:02
>>404 ExecuteExcel4Macro("'C:\[Book1.xls]Sheet1'!R1C1")
これでBook1のSheet1でA1の値を取得できているようです。
裏技とか書いてました。
406 :
デフォルトの名無しさん :2007/11/06(火) 15:15:23
追記 ファイルの中にExcelを2つ用意して、1つにプログラム。 もう1つをBook1としてSheet1のA1に何か書いときます。 で、Book1は開かずにプログラムを書いた方だけ開いて、 ユーザーフォームのラベルに表示させました。
これは、すごい
それは参照してるわけだから 参照先でどうやっても参照元は変えられないでしょ 超ウラワザがあるかもしれんが結局裏でADO操作してとかだから それならADOでやればいい そんな都合のいいお手軽な方法はないよ
409 :
デフォルトの名無しさん :2007/11/06(火) 17:28:23
>>408 ありがとうございます。
当方初心者でADOが何かすらもわかりません。
もう一度勉強します。
ありがとうございました。
"表示せずに"ならいくらでも誤魔化しようがあるけど "開かずに"は不可能 ExecuteExcel4Macroも"開かずに"ではなく"表示せずに"だし 裏技でもなんでもない
開かずにってどうせ見えなければいいんじゃないの?
412 :
デフォルトの名無しさん :2007/11/06(火) 22:18:18
ボタンのテキストを書き換えるのに Set s = ActiveSheet.Shapes("Button 1") s.Select Selection.Characters.Text = "hogehoge" とすれば書き換わりますが、ボタンがセレクトされるのがイヤなので s.Characters.Text = "hogehoge" としたら、「オブジェクトは、このプロパティまたはメソッドをサポートしていません」 と怒られました。セレクトせずにテキストを書き換えるにはどうしたらいいですか?
まず、そのわがままな性格を何とかしれ
ヒント:Caption
415 :
412 :2007/11/07(水) 00:00:59
>414 UserFormオブジェクトのプロパティCaptionを使えばいいようですが UserFormオブジェクトはどうやって取得するのでしょうか?
聞く前に試せば? オブジェクトには名前が付いてるでしょ
>>412 Dim s As Shape
Set s = ActiveSheet.Shapes("Button 1")
s.TextFrame.Characters.Text = "HELLO"
みたいよ
418 :
412 :2007/11/07(水) 00:50:19
>417 ありがとうございました。解決できました。 selectしたら、textFrameを書かなくてもいいんですね。。。
つーか、「選択したもの」のキャプションを変えるか、「TextFrame」のキャプションを変えるかの違い。
UserFormの場合は?
しつけーよカス
VBAといえどもプログラミングするなら 使い込んで慣れるよりも調べ方を覚えるほうが先
>>422 その通りだね
VBAっていうよりも仕事をする上で必要な事かもね。
調査がうまい人ってその時々の対応に長けてるところがあるしね。
424 :
デフォルトの名無しさん :2007/11/07(水) 16:25:31
たびたびすみません。 昨日、bookを開かずに作業が不可能なのは理解できました。 ありがとうございました。 今日は、 『それなら、タスクバーに開いてるbookが表示されないように』 と言われて調べてますが、どうもよくわかりません。 よろしくお願いします。
425 :
デフォルトの名無しさん :2007/11/07(水) 16:34:07
>>424 質問スレだからガンガン質問し続けるのは悪くはないが何をしようとしてるの?
あと、どうもよくわからないって何が分からないのかな?
質問の意図をちゃんと把握できていないと自分のためにならないよ。
聞かれた事を右から左に受け流すだけなら誰でも・・・
>>424 Application.Visible = False
じゃないの?
実行するとExcelが見えなくなって操作不能になるから
注意してね。
427 :
デフォルトの名無しさん :2007/11/07(水) 16:44:43
ありがとうございます。 ユーザーフォームで作業をし、エクセルのbookをデータベースとして 使うシステムを作ってます。 タスクバーに作業中のbookが出てくるのはよろしくないということで それを見えないようにという指示でした。 『何をどう書けばいいかわからない』って、甘えすぎですね。 すみません。 Application.Visible=False、やってみます。 ありがとうございます。
いや、だから、やってからレスしろって・・・
>>428 天然の人みたいだから、もう細かい話はいいんじゃね?w
430 :
デフォルトの名無しさん :2007/11/07(水) 17:02:03
天然で申し訳ないです。 早くレスした方が良いのかと思って。 Application.Visible = Falseで出来ました。 ありがとうございました。
>>427 さんが今作っているもので質問があります。
・ユーザーフォームで作業する。
・ブックをデータベースとして使う。
・タスクバーに作業中のブックが表示されないようにする。
ブックでデータ管理をしているように読めるのですが、
データってxmlとかで管理するものじゃないでしょうか?
ちょっと分からなかったのでどなたか助言をお願いします。
>>431 ここはExcel VBAの断片的な質問のスレだろうから、
427タソが最終的に何をどうしたいのかっていう問題は、
どうでもよいと思いますが。
AさんBさんCさんのA.xlsB.xlsC.xlsを まとめるXさん用ってパターンだってあるだろ
>>432 断片的なのでどうしたいかとかは関係ありません。
427さんのやりたい事とか関係なしにデータ管理の仕方について教えて頂きたいです。
EXCELだけでRDB組んだときはマジで泣けた
xmlってデータベースとしてそんないいものかどうか OSの違いを吸収できるのは利点だろうが 速度的に根本的に欠陥あるだろ
xmlでDBやってる奴が居て、どうしてもxmlじゃなきゃ困るんだけど遅くて叶わないというので ソース見てみたら、初心者入門サイトに載ってるような真っ当なコード書いてるので手直ししてやった 結果、1100%程度の速度アップ(同じ処理が11分の1の時間で終了)に成功した 遅い、ダメだ、と文句だけ言うのは簡単だが、バカとナントカは使いよう xmlは汎用性重視な為、普通に使ってたのでは限定用途では利点が活きにくい しかし使い方次第では限定用途特化型のものを超えることはなくても、 実用に充分なパフォーマンスを発揮することも可能な場合が多い まぁxmlの使い方というよりは頭の使い方の問題かもな
どういうネタ? 笑わせたいの?
よくわかんないけど xmlって使われてるの設定ファイルぐらいだよね いい使い方おちえて?
Excel 2007ワークブックとか、XMLHTTPでネットワーク通信とか、 設定ファイルどころでなくあちこちで使われている。
いい使い方おちえて?
<?mso-application progid="Excel.Sheet"?> <hoge> <fuga>fuga</fuga> hoge </hoge>
むかーしから「OSや言語が違うけれどデータ型を双方向に変換したい」 という需要があった。そのためには「型名」と「値」を文字列で書いちゃえば いいんだけれど、昔のコンピュータはいまほど処理速度もメモリもなくて 利用されることはあまりなかった。 90年代から、コンピュータの性能が向上してきて文字で書いても大丈夫になってきた。 そのころ「データ交換するときにXML使えばいいんじゃね?文字コードの扱いも整理されているし」と 考えた人たちがいて、使ってみたら便利だったんで今みたいに使われるようになった。 元々XMLは、SGMLの進化版だから「形式的な文章」を表記するための規格。 データ交換のために考えられたものではない。が、データ交換によく 利用されている。 というわけで、1台のPCで完結するようなシステムでは XMLの出番はあまりない。設定ファイルの記述にXMLが利用されている理由は、 オブジェクトのシリアライズデータを人が読んだりテキストエディタで編集したり したいからだと思われ。
むかーしの話は関係なくてHTMLが流行っただけ。
ここは半可通がほろ酔い気分で講釈たれるスレじゃねーぞ
449 :
デフォルトの名無しさん :2007/11/08(木) 14:59:18
テキストファイルから先頭の1行を読み込んで返すFuncitonを 作成したのですが、なぜか特定のCSVファイルだけ、先頭の2行を1行分にして抽出してきてしまいます。 "1行目 2行目" のような感じです。 何が原因でどう対処すればいいか困っています。だれ偉い人教えてください! Public Function ReadOneLine() As String Dim Fso As Object Dim Tso As Object Dim line As String Set Fso = CreateObject("Scripting.FileSystemObject") 'ファイル名を指定する Set Tso = Fso.OpenTextFile(FileName:=m_strInputFile, IOMode:=1) With Tso 'ファイルポインタが終端になければ(空ファイルでなければ) If .AtEndOfStream <> True Then line = Tso.ReadLine Debug.Print line End If .Close End With 'オブジェクトの解放 Set Tso = Nothing Set Fso = Nothing ReadOneLine = line End Function ちなみにCSVファイルの文字コードはShift-JISで改行コードはCR+LFです。
450 :
デフォルトの名無しさん :2007/11/08(木) 15:14:31
451 :
デフォルトの名無しさん :2007/11/08(木) 15:41:07
>>449 知人からサンプルでもらった5つのCSVファイルの中の1個だけ、
上記の症状になってしまうんです。
秀丸エディタでそのCSVファイルを開いて
文字コードや改行コード、コンマの数や""の有無を確認したのですが、
他のCSVファイルと特に変わったところが無いのです。
452 :
451 :2007/11/08(木) 15:42:31
バイナリエディタで確認してみたら?
454 :
デフォルトの名無しさん :2007/11/08(木) 16:08:17
>>451 困ったねー
その症状がどういうときに発生するかつかめれば打開できるんだろうね
>>449 なら何か打開できそうな気がするけどな・・・
実は長い1行で単に折り返してるから2行だと思い込んでるなんて落ちだと寒いね
可能ならそのcsvファイルをアップロードしてみたら?
>>455 予想外の動きしてるときほど見落とすもんなぁ
症状からして普通にありそだな
>>449-451 FAQだと思うんだがExcelのセルの中で改行されていると
CSVで出したときそこにLFだけが入るから
別のプログラムでそれを読み込むと2行(以上)に
なっているように見えることがあるし
LFを正しく処理していない場合は1行に2行分はいることになる
>>459 FileSystemObject.ReadLineはCR+LFだけではなく、LFのみでも改行とみなして一行読み込む。
(ただし、CRのみの場合は改行とはみなさない。)
やはり、バイナリエディタできちんと改行コードがあるかどうかを確認するのが先決だね。
CRLFとLFの混在ならFSOじゃなくてADOで処理だね
OS XP EXCEL 2000 shellでリモートデスクトップを呼び出す所までは、 自分で調べて理解出来たのですが、 呼び出したリモートデスクトップに値を投入するやり方がわかりません。 どなたかご教授願います。
>リモートデスクトップに値を投入する すいませんが、意味不明です
464 :
462 :2007/11/08(木) 18:49:39
>>463 申し訳ございません、プログラミングをする事が初めてなので…
リモートデスクトップを呼び出してそこに
サーバ名等を投入し接続ボタンまで自動的に押すマクロが組みたいのです。
466 :
462 :2007/11/08(木) 19:14:14
>>465 ありがとうございます、頑張ってみます。
>打開できたらどうやったか書き込んでねー。
ご期待に添えられるように(苦笑)
sendkeys
キーボードから入力されたかのように、現在の入力フォーカスのあるウィンド ウにデータを送ります。 特殊キーを送る場合は、次のとおり。 {ENTER} Enter キー {ESCAPE}, {ESC} Esc キー {TAB} Tab キー {INSERT} Insert キー {DELETE}, {DEL} Delete キー {BACKSPACE}, {BS}, {BKSP} Back space キー {LEFT} ← キー {RIGHT} → キー {UP} ↑ キー {DOWN} ↓ キー {PGUP} Page Up キー {PGDN} Page Down キー {HOME} Home キー {END} End キー {PRTSC} Print Screen キー {SCROLLLOCK} Scroll Lock キー {BREAK} Pause キー {NUMLOCK} Num Lock キー {CAPSLOCK} Caps Lock キー {F1} 〜 {F12} F1 〜 F12 キー (ファンクションキー) + Shift キー ^ Ctrl キー % Alt キー ** +, ^, % で、複数のキーを対象にする場合は、() でキーを囲む。 +(AB) は、シフトキーを押しながらの AB になります。 ** 画面コピーとしての {PRTSC} を sendkeys することはできない。 Windows API などを使用して対処するしかない。 ** 同じキーをリピートするには、{RIGHT 6} とすると → が 6 度押された 動作になる。
>>466 EXCEL VBAでもできるけど、厳密に言うとスレ違い
そういうのはWSHからSHELLオブジェクトで処理するのが普通
ただMSTSCコマンドにはパスワード指定オプションがないみたいなので、
その辺りはSendkeysでキーを送ってやるなりする必要がある
繰り返すけどEXCELでやる必然性は全くないので
470 :
462 :2007/11/08(木) 22:28:25
>>467 >>468 本当にありがとうございます。
まだまだ自分の勉強が足りませんでした。
>>469 WSHというのは調べてみるとVBS…ですかね?
エクセルで機能の一覧表があってその横にボタン作ってウマー
なんて考えていたんですが。
ありがとうございました、勉強してみます。
caption で上付文字は入力できますか? a^2をきちんと表示したいんですが。
>>470 Excelからスクリプトを引数付きで呼べばいい
473 :
デフォルトの名無しさん :2007/11/09(金) 11:27:51
If Range("a1").Value > 10 Then _ error_msg = MsgBox("error", vbOKCancel + vbInformation) If error_msg = vbOK Then Exit Sub End Sub ----- この場合、「error_msg」の変数定義は何になるんですか variantにしても「型が一致しません」と出てしまいます(;_;)
1つずつステップで確認してみ
>>473 VBAのエディタ上でMsgBoxの上にキャレットを置いてF1キーを押す
476 :
473 :2007/11/09(金) 12:13:36
ありがとうございました! いけました if total_value <> 0 and total_value <> "" then の場合、total_valueの変数定義はvariantにするしかないんでしょうか。 こちらではstringでもいけるようなんですが、ということはstringは整数を内包している?
477 :
449 :2007/11/09(金) 12:16:46
バイナリエディタで調べてみたところ、
その先頭行だけCRでした。ショック。。(他の行はCR+LF)
とりあえずCRも改行コードとして認識できる方法を探してみようと思います。
>>461 私の経験からADOを利用したCSVファイルの先頭行の読み出し方法は
レコードセットのFieldsオブジェクトを参照する方法しか思い浮かばないのですが
他にも良い方法がありますか?
>>476 それ普通にIntegerかDoubleで受ければいい
空白は0になる
関係ないけど変数定義じゃなくて型と呼んでくれ
479 :
デフォルトの名無しさん :2007/11/09(金) 13:41:20
>> 478 ありがとうございます
480 :
デフォルトの名無しさん :2007/11/09(金) 16:06:09
xpで2003です。 ユーザーフォームのリストボックスに表示されている値を 新しいシートに入れたいのですが。 リストボックスの値の元になっているシート上のデータは使えません。 チェックされているかどうかに関係なく、表示されている値全てをそれぞれセルに入れたいのです。 どなたかよろしくお願いします。
With Worksheets("Sheet1") .Range(.Cells(1, 1), .Cells(UserForm1.ListBox1.ListCount, 1)).Value = UserForm1.ListBox1.List End With
Dim i As Integer For i = 0 To UserForm1.ListBox1.ListCount - 1 Worksheets("Sheet1").Range("A1").Offset(i, 0).Value = UserForm1.ListBox1.List(i) Next
483 :
デフォルトの名無しさん :2007/11/09(金) 16:34:44
>>481 ,482様
本当にありがとうございます。
希望通りに出来ました。
>>477 なんでレコードセットが出てくるんだよ
ストリームだストリーム
485 :
477 :2007/11/09(金) 21:32:11
>>484 なるほど。ちょいリファレンス読みながらやってみます。
486 :
477 :2007/11/10(土) 11:57:28
おかげさまでなんとかできました。
作ったサンプルになります。
'改行コードがCRのデータ抽出
Sub StermTest()
Dim stm As ADODB.Stream
Dim strFile As String
Dim line As String
Set stm = New ADODB.Stream
strFile = "hoge.csv"
stm.Type = adTypeText 'ストリーム内のデータ型を設定する
stm.Charset = "Shift_JIS" '読み取り時の変換文字コードを設定する
stm.LineSeparator = 13 'CR=13 改行コードを設定する
stm.Open
'Streamオブジェクトにファイル内容を読み込む
stm.LoadFromFile strFile
'1行目を抽出する
line = stm.ReadText(-2)
Debug.Print line
stm.Close
'オブジェクト解放
Set stm = Nothing
End Sub
>>484 こんな感じですよね?
>>484 >こんな感じですよね?
yes(^ω^)b
488 :
デフォルトの名無しさん :2007/11/12(月) 14:42:07
皆様、お疲れ様です。 ユーザーフォーム上に多数のテキストボックスやコンボボックスがあります。 クリアボタンを押す時に 「編集中の内容は破棄されます」とメッセージで出すのですが、 保存ボタンを押しているのであればこのメッセージは出しません。 If combobox1.value=worksheets("sheet1").cells(2,2)(保存ボタンでこのセルに入力されます).value Then Else If MsgBox ("編集中〜破棄されます",vbOkCancel) =vbCancel Then Exit Sub End If End If この考え方でよろしいのでしょうか? 試してみると、両方ともに同じ数値が入っていてもメッセージボックスが立ち上がってしまいます。
cells(2,2).value
>>488 > この考え方でよろしいのでしょうか?
いい。
If分にbreak pointを設定して、止まったらイミディエイトで「?worksheets("sheet1").cells(2,2).value」、
「?combobox1.value」として内容を確認してみるべし。
valueついてたか(汗
492 :
488 :2007/11/12(月) 17:24:42
ありがとうございます。 やってみようと思った矢先、違う項目について言われたので そちらに時間をとられてます。 考え方が間違ってなかったとわかり、心強いです。
493 :
デフォルトの名無しさん :2007/11/12(月) 21:41:20
質問なのですが、 メインのsubから、複数受けて、1個の値を返すというのは、わかったのですが、 3つの値を受けて、5つの値を返す、functionもしくはsubを作りたいのですが可能でしょうか? その場合の記述方法を教えていただきたいのです。お願いします。
sub savu(a,b,c,d,e) a = 1 b = 2 c = 3 d = 4 e = 5 end sub
ByRefを使えばできるけど多用するのは良くない 返す5つの値をひとまとめにしたクラスを作ってそのオブジェクトを返す
496 :
495 :2007/11/12(月) 21:49:11
VB.NETスレと間違えてた
クラスは大げさだから構造体か、
>>494 でもいいよ
497 :
494 :2007/11/12(月) 21:49:36
>>495 ありがとうございます。
classというのがあるのですねw
独学のため、知りませんでした。勉強してみます!
498 :
494 :2007/11/12(月) 21:53:04
あ・・・
>>494 がありましたw
ちょっと調べてみます。
ありがとうございます。
499 :
494 :2007/11/12(月) 22:02:47
連続で、ごめんなさい。 これじゃ、だめなのはわかってるのですが乗せますw こんな感じの事がしたいんです。 Sub TEST() Dim a, b, c, z a = 1 b = 2 c = 3 Call TEST2(a, b, c) ←ここで、Test2にa,b,cを入れて、Test2のd,e,f,g,hの値を取得したい z = d + e + f + g + h←取得したd,e,f,g,hを使って計算したい。 End Sub Sub TEST2(d, e, f, g, h) Dim d, e, f, g, h d = a * 2 e = b * 3 f = c * 4 g = a * b h = a * c End Sub
Sub TEST2(a, b, c, d, e, f, g, h)
>>499 Sub TEST()
Dim a, b, c, z, d, e, f, g, h
a = 1
b = 2
c = 3
Call TEST2(a, b, c, d, e, f, g, h)
z = d + e + f + g + h
MsgBox (z)
End Sub
Sub TEST2(ByVal a, ByVal b, ByVal c, ByRef d, ByRef e, ByRef f, ByRef g, ByRef h)
'略(一緒)
End Sub
d, e, f, g, hの組み合わせに何か意味があるんだったら、
ユーザー定義型を使ったほうが見やすくなる
502 :
494 :2007/11/12(月) 22:18:01
>>500 なるほど!できました!
3個いれて5個入れたいなら、最初から8個にしとけって事ですねw
このやり方って、当たり前なんですかね〜。自分の頭の固さにがっかりですわw
ありがとうございました。
> 当たり前なんですかね 当たり前ではない 見づらいコードなだけでメリットがない 誰かが書いていた通りクラスか構造体を使うか、戻り値を配列で返却するのが普通
型一緒なら配列でいいしょ
505 :
494 :2007/11/13(火) 08:55:56
>>503 >>504 ありがとうございます。
昨日はじめたばかりで、配列・クラス・構造体を知らないんですw
勉強して、すっきりさせたいと思います。
クラス、構造体は使わなくても何とかなるけど、配列を使わないで プログラミングは困難だね がんばってね
>>505 出力引数を使うんだったらByVal/ByRefはサボらず書くように
508 :
デフォルトの名無しさん :2007/11/13(火) 23:22:28
VBAで記述した関数( 例 func() )をワークシートから呼び出す場合に SUM関数を呼び出す場合などのように引数のツールチップを表示させる方法がわかりません。
イベントとコントロール使わないと無理ジャマイカ?
510 :
488 :2007/11/14(水) 09:19:31
先日はありがとうございました。 If combobox1.value = worksheets("sheet1").cells(2,2).value And _ combobox2.value = worksheets("sheet1").cells(2,3).value And _ textbox1.text = worksheets("sheet1").cells(2,4).value Then Userform.show Else Msgbox "〜" End If イミディエイト ?worksheets("sheet1").cells(2,2).value 19(19の前に半角の空白があきます) ?combobox1.value 19 このようになり、同じ数値がそれぞれ入っているのにメッセージボックスが開いてしまいます。 Andの使い方が悪いのでしょうか? それともイミディエイトの表示のように半角の空白があるのが悪いのでしょうか? よろしくお願いします。
512 :
488 :2007/11/14(水) 09:52:31
>>510 >>combobox1.value = worksheets("sheet1").cells(2,2).value And _
>>combobox2.value = worksheets("sheet1").cells(2,3).value And _
>>textbox1.text = worksheets("sheet1").cells(2,4).value
こいつを満たしてないからメッセージボックスが出ます。
514 :
488 :2007/11/14(水) 10:25:19
>>513 様
ありがとうございます。
条件を満たしていない理由を知りたかったのです。
どうやら型が違ったようです。
515 :
デフォルトの名無しさん :2007/11/14(水) 10:26:15
Range("A1").Formula = "= IF(H5="""","""",IF(ISERROR(VLOOKUP(H5,table!$A$1 こういう感じで、A1セルに関数を入れるとき、関数の途中でアンダーバーによる改行 を行うことは可能ですか? 改行を入れると必ず次の行で、「修正候補:ステートメントの最後」が出てしまいます。
改行できないので、あきらめてそのまま記述するかバッファを介して&で連結しましょう e.g) strBuf=IF(ISERROR( strBuf=strBuf & "VLOOKUP(H5,Table!$A$1,FALSE)" strBuf=strBuf & "),"hoge","fuge") ってな感じで
↑二重引用符で囲ってないところは脳内補完ヨロ
518 :
515 :2007/11/14(水) 18:34:20
>>516 自己レスでおま。
以下のようにするといけました・・・。
IF(ISERROR(VLOOKUP _
& "(H5,テーブル!$A$50:$B$97
519 :
デフォルトの名無しさん :2007/11/14(水) 21:43:58
基本的なところなんですが、 Cells(1,1).Value = "(" & a & ")" とすると、a=100とすると、(100)とでると思ったのですが、-100と出ました。 これは、文法が間違っているのでしょうか?
Excelでは数値としての(100)も-100を意味する。 書式設定でも負の値の表現に括弧で括る表記が選べるのを見たことがあるだろう。 一番手っ取り早い対処法は、おそらく"'(" & a & ")"のようにアポストロフィを頭に置くこと。 ほか正攻法があると思うが、やったことないので詳しくは知らない。
521 :
デフォルトの名無しさん :2007/11/14(水) 21:57:45
>>520 ありがとうございました!できました。
確かに、書式設定で見ると()もありますね。
すみませんこちらのスレで質問させて下さい FileSystemObjectを使ってGetFolderでネットワークのパスを取得すると \・・・\ のような文字化けを起こすのですが、どのように回避すればよいのでしょうか?
文字コード
すみせん。 プログラムを教えて欲しいのですが、 Excelで入力されているIPアドレスを 頭以外、全て三桁で表すようにするにはどうすればいいのでしょうか? 例えば、 99.1.2.3 → 99.001.002.003 という風に変換したいです。
526 :
524 :2007/11/15(木) 22:15:29
>>525 ご丁寧にありがとうございます。
試してみます。
527 :
デフォルトの名無しさん :2007/11/16(金) 10:16:27
msgboxのタイトルをシートで一括設定したいのですが、方法が分かりません(*_*)
528 :
デフォルトの名無しさん :2007/11/16(金) 11:07:16
Dim XXX As String XXX = workbooks("book1").worksheets("sheet1").cells(1,1).value ※cell(1,1)に表示したい文 MsgBox XXX 間違ってる?
529 :
デフォルトの名無しさん :2007/11/16(金) 11:20:14
>>528 ありがとうございます
get_value = MsgBox("計算が終了しました", vbOKOnly + vbInformation, "給与合算")
上記の「給与合算」にあたる部分ですね・・・。
msgbox "hoge", vbinformation, range("sheet1!A1").value とかじゃ駄目なのか?
531 :
デフォルトの名無しさん :2007/11/16(金) 12:09:59
>>530 なるほど、その手がありましたか
ところで関係ないですが、文字列を「hoge」「huge」にするのって、
何か意味があるんですか。
532 :
デフォルトの名無しさん :2007/11/16(金) 12:15:10
すいません、この間もここの方たちに助けていただいたものです。 また、力を貸していただきたいです。 SA-2 1 s5004878815 8635A129 2 s5004878811 3 s5004879056 4 s5004879819 5 s5004879066 : : このように列が並んでいて、一行ごとに20行列を挿入させたいです。 ネットで関連サイトからコピペしてみましたが、1度マグレでできましたが もうできません。 ここにいる方達にとっては、簡単すぎるのかも知れませんが 私にはわかりません。 よろしくお願いします。
おちつけ。 行と列は別物だ
>>532 >>ネットで関連サイトからコピペしてみました
このコピペしたロジックの処理はちゃんと理解できてるの?
もし理解できているならどこがおかしいか?むことができると思うけど・・・
>>533 の件は同意w
>>531 "hoge"等は、特に意味の無い文字列とかの場合に
使われる文字だよ
>>530 の場合はメッセージBOXに"hoge"と表示される
536 :
532 :2007/11/16(金) 13:02:59
ご返答ありがとうございます。 今一行ずつ地道に挿入し続けています。指が痛くなってきました笑 列と行間違えてますね、ごめんなさい。 ロジックもほとんどわからないです。 ごめんなさい。
537 :
デフォルトの名無しさん :2007/11/16(金) 14:29:58
これで、いいんじゃね?w(爆 Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert Selection.EntireRow.Insert End Sub
謝らなくていいから、一般的に説明できないなら具体的な例を示してくれ それに対してどういうマクロを動かしてどうダメだったのか 自分で理解する気がないならそもそもスレ違い
539 :
デフォルトの名無しさん :2007/11/16(金) 15:10:22
>>532 紙にフローチャートでも書いてみると理解しやすいかもわからん。
>>532 隣の列に連番を振って下に同じ連番をコピー
A B
1 aaa 1
2 bbb 2
3 ccc 3
4 ddd 4
5 1
6 2
7 3
8 4
B列で並べ替え
詰まっちゃったな 何とか理解してくれ
542 :
532 :2007/11/16(金) 16:13:03
537様のをボタンをつくりました。 ありがとうございました。 理解しようと本などを読んだりしていますが、難しいです。 みなさまどのように学んで、自分で作れるようになったのでしょうか。 すごすぎです。 だめだったのは、テンプレが6行ごとに1行空白行を挿入で 私が数字を変えたため、できなくなったと思います。
>>542 ,532
とりあえず解決(?)したようでよかったね。
>>理解しようと本などを読んだりしていますが、難しいです。
それは多分ただ眺めたって感じなのかも・・・
とりあえず例題などを実際に入力してフローを理解する必要が最低でもあると思います。
これができればどっかでつまづいた場合でもネットで調べるなり自力で応用力がつくと思いますよ。
>>だめだったのは、テンプレが6行ごとに1行空白行を挿入で
>>私が数字を変えたため、できなくなったと思います。
この説明じゃ相談されても困るよね・・・
相談の仕方も勉強の一つです。頑張って下さいね!
544 :
537 :2007/11/16(金) 16:24:16
Σ(・∀・)うそ、マジでっ いつもクレクレ君の俺が役に・・・(T-T)
なんでもいいから一般的なプログラミング言語が一つでも身についてたら他のはすぐ使えるからな この板では先に他のが使えた人が多いんじゃないの
書けないなら、まず「新しいマクロの記録...」をしてみればいいと思うのだが。 そこから読解できるだろ?
プログラミング経験がないと無理だろ
>>457 っつーかExcelVBAの本読んでるんだから、
読んで手を動かして理解することくらいできるんじゃないのかなぁ・・・
もちろんマクロを記憶させて読解するのもありだよ。
条件として分からない時確認する本やサイトがある事ね。
すいません、エクセルVBAで数万件のデータを処理するプログラムを作っているのですが、 VBAはクソ遅いんで、C++で自作のdllを組み込んでやろうと思うのですが、 ぐぐっても有益な情報は得られませんでした。 分かりやすく解説したホームページなどありませんでしょうか?
あ、OSは2000sp4、エクセルは2000、cはBCCを使ってます。 ちなみにCPUはPEN2、360mhz、メモリ192mb・・・・
くそ仕事遅せーくせにマグロかよ
探し方が悪いだけだろ DLL呼ぶ方法なんていたってポピュラーだし VBA用に特殊なことしてるわけでもないし
>>551 ネイティブよりVBAのが遅いのは確かだが、たかだか数万件のデータで
クソ遅いなんて思うほどなら、お前の技術不足と言わざるをえない
>>551 どんなことやってるんだ?
VBAでも数万件くらい普通サクサクだぞ?
API VBA でググれば出てくると思うけど、そういう事ではない?
ぐだぐだ言わないで答え教えてやれよ。 stacallな関数をexportしたdllを作って、vbaでdeclare sub/functionすればいい。 知らない単語はググれ。
まー確かにやる内容によっては、遅いっちゃ遅いな。 T5500+Excell 2007で、次のコードが2.5秒くらいかかるし。 For i = 1 To 10000 Cells(i, 1).Value = Rnd() Cells(i, 2).Value = Cells(i, 1).Value Next やりたい内容と、いまどれくらいかかてるか、どれくらいにしたいかを書いたほうがいいな。 C/C++にしたから、なんでも自動的に劇的に速くなるわけじゃないぞ。 意外とVBAって速いんだぞ。
ちなみに上のコード、screenupdatingをfalseにすると、1.4秒くらいになるけど、 それでも遅いっちゃ遅いな。
直接セルに値代入が遅いのはTips Dim buf(9999, 1) As Variant For i = 0 To 10000 - 1 buf(i, 0) = Rnd() buf(i, 1) = buf(i, 0) Next Range("A1:B10000") = buf
>>563 便乗で聞いちゃうけれど、
装飾情報(フォント、セルの色など)を高速に書き込む方法ってのは
あるの?
>>563 いや、そういうことが言いたかったわけじゃないんだけどね・・・
566 :
551 :2007/11/17(土) 13:05:19
みなさんどうもです。頂いたキーワードで再度ググッて見ます。 やってることは、バイナリファイル(構造化されたデータ)を開いて、 項目ごとに対応する日本語に置き換えて、セルに放り込んで表示、 という物です。 データ数は4万ぐらいです。1つのデータについて項目の個数は50個ぐらいですね。
>>546 よくわからんがこんなことですか?
With Range("A1:B10000")
.Font.Size = 12
.Font.ColorIndex = 3
.Interior.ColorIndex = 4
.Borders.ColorIndex = 3
End With
>>561 DLL呼ぶって言ってるんだから
単純なデータ操作じゃなくて、時間のかかる数値計算でもやるんじゃね
>>563 Variantは使わない方がいいぞ
「セル範囲の値を取得する」変数はVariant型である必要があるが
「セル範囲に代入する値を一時格納する」配列変数はVariant型である必要は無い
これも件のTipsの一部なので覚えておくように
>>566 ありそがちなのを挙げてみる
String型の連結を何度も使用している -> 固定長StringもしくはByte、Integerの配列を使え
読み込んだバイナリをForループでコピーしている -> RltMoveMemory
セルに1つづつ代入している -> String型の2次元配列を作って一気に代入
読み込んだ一時データを作業用シートに入れている -> 問題外
572 :
546 :2007/11/17(土) 18:52:12
>>547 やっぱり、そんな感じになるのか。
わざわざサンスコ
C++でdll作って云々というレベルの人がなんでAPI知らないんだよ w
>>573 さぁ…DLLばっか作ってたんじゃね?w
んでもってAPIは苦手で覚えもしなかったとかw
VB.NETで書けば?w ヘタにC++で書くより速いよ
>>568 数値計算もね、意外とVBAでも速いんだよ
>>566 4万×50個のデータをセルに表示するってこと?だとすると、どうあがいても速くはならない。
それとも、「対応する日本語への置き換え」が遅いのか?だったら、今どうやってるか書いてみるべし。
何が遅いのかわからない?計測しろ、今すぐ。
578 :
577 :2007/11/18(日) 10:15:43
>>577 > 4万×50個のデータをセルに表示するってこと?だとすると、どうあがいても速くはならない。
これは、C/C++でDLLを作っても速くはならないってこと。念のため。
>>571 > 読み込んだバイナリをForループでコピーしている -> RltMoveMemory
つLet
もうちょっと具体的に内容と時間がかかってる箇所を書けば、具体的な回答が返ると思うぞ。 まー、速いCPU使ったり、メモリ増設したりってのが劇的にスピードを速くする近道だったってな こともあるかもしれないけど。
581 :
デフォルトの名無しさん :2007/11/18(日) 23:14:07
ユーザーフォームを印刷する方法ありませんか? ネットで検索すると出来ないと書いてあったんですが 本当は裏技があるとかんぐっています。
PrintScreen
>>581 Win32API使うといいよ
でもスレ違いだからあとは自分で調べてね
CopyMemoryだろ、普通
585 :
デフォルトの名無しさん :2007/11/19(月) 01:36:29
CSVファイルにADOを使って接続する際に、 各列のデータ型をschema.iniで定義できますが、 Excelのワークシートに接続する際には どうやって定義すればいいんでしょうか??
587 :
デフォルトの名無しさん :2007/11/19(月) 07:54:01
printrormだったか、formprintだったかたしか命令あったきがする。 今携帯からなので、あとは自分で調べてみてくれ
>>586 RltMoveMemoryとか書いちゃう奴がいるから、CopyMemoryを普通にしといたほうがいいんだよ
590 :
デフォルトの名無しさん :2007/11/19(月) 23:45:57
【OS, Office】2000 エクセル4.0マクロ(関数)ってOffice2007でもサポートされてますか?拡張子.xlsで。 昔作ったファイルがVistaで動作するかどうか知りたいのです。 MSのサイトで検索したところ、どうやら使えはするようなのですが、 買って実験しろ、ってのは最終手段でお願いします。
余裕で使える
>>589 CopyMemoryの方が直感的で間違わないだろ。
だからそれを普通にしといたほうがいいんだよ。
RltMoveMemoryとか書くアホでも使えるし。
>>592 本来MoveMemoryな関数をCopyMemoryって本当に直観的か?
なんか無批判にAPIビューアの宣言を盲信してんだか、
自分がそれに慣れてるから勝手に直観的とか思い込んでるだけじゃね?w
Rltと書いたのがよほど悔しかったんだな
なんだか良くわからんが、::MoveMemoryが普通だろ。
597 :
585 :2007/11/20(火) 10:11:46
お取り込み中失礼しますが
どなたか
>>585 もよろしくお願いします
>>597 マクロの記録で、データ→外部データの取込み→テキストファイルのインポートでウィザードを操作してみれば大体分かる。
>>596 RtlMoveMemoryとか書こうとするから恥かくんだよwww
599 名前:デフォルトの名無しさん 投稿日:2007/11/20(火) 11:17:07
>>596 RtlMoveMemoryとか書こうとするから恥かくんだよwww
>>599 なんだ、お前がいいたかったのは結局typoなのか
2ちゃん初心者なのかしらんが、んなことでいちいち粘着すんな、きめえ
両方宣言すればいいじゃない。 Declare Sub MoveMemory Lib "kernel32.dll" Alias "RtlMoveMemory" (Destination As Any, Source As Any, ByVal Length As Long) Declare Sub CopyMemory Lib "kernel32.dll" Alias "RtlMoveMemory" (Destination As Any, Source As Any, ByVal Length As Long)
>>604 これはどうすんだ?
Declare Sub CopyMemory Lib "kernel32.dll" Alias "RtlCopyMemory" (Destination As Any, Source As Any, ByVal Length As Long)
もうどうでもいい
>>605 kernel32.dllを見てみろ。RtlCopyMemoryなんて存在しない。
Win32APIの知識のない奴ばっか
609含めて、ね。
きめぇ
いつまで続くんだよ・・・
>>571 から数えて今日で5日目だぞ・・・
Nowから「今月の末日の最終秒の日時」を得るにはどうしたら良いでしょう? 「今月の末日の最終秒」は、たとえば今日だと2007/11/30 23:59:59です。
DateAdd("s", -1, DateAdd("m", 1, DatePart("yyyy", Now) & "/" & DatePart("m", Now) & "/1"))
>>615 ありがとうございました。
感動しました。
618 :
デフォルトの名無しさん :2007/11/21(水) 13:20:34
中の値はどうでもよくて、 結合したセル自体を他の場所にペーストして、 結合セルを増やしたい。 簡単そうなのになんでできないんだorz
Office2002 WindowsXP AppActivateの使い方がわかりません。 shellの所でタイトルの指定が出来ないです。 どなたかお教え下さい。
知りません
>AppActivateの使い方がわかりません。 よhelp >shellの所でタイトルの指定が出来ないです。 そのとおり。できない。よhelp
WSHからApplication.ExecuteExcel4Macroでマクロを呼べますが、 VBAの文を実行する方法はないのでしょうか? 昔は出来たとか聞きましたが
VBAで関数書いて呼ぶしかないんじゃないかなぁ
ひょっとして、application.runが知りたいのか?
628 :
デフォルトの名無しさん :2007/11/23(金) 22:34:37
CSVファイルをエクセルで開いたときに、 012,345を一つのセルに表示させようとして、 ="0120,345"としても"0120,345"としても 元の通りに表示されません。 どうすればよいでしょうか?
>>628 VBAの話だったら、CSVファイルの拡張子をtxtにいったん変えて、マクロを記録しながら
読み込むとどうすればいいかわかるかもよ。
>>624 var oExcel = new ActiveXObject( "Excel.Application" );
var oWorkBook = oExcel.WorkBooks.Open("C:\\test.xls");
var oModule = oWorkBook.VBProject.VBComponents.Add(1);
var sCode = "sub VBAMacro()\r\n" +
" msgbox \"VBA Macro called\"\r\n" +
"end sub";
oModule.CodeModule.AddFromString(sCode);
oExcel.Run("VBAMacro");
C#のサンプルを参考にしたのでJScriptね
631 :
629 :2007/11/23(金) 22:47:28
あれ?今手元で実際に試してみたら、ちゃんとCSVファイルをダブルクリックで 普通に読めたけど。 カンマつき数値になるのがいやだってこと?
632 :
629 :2007/11/23(金) 22:49:43
>>624 import win32com.client
oExcel = win32com.client.Dispatch('Excel.Application')
oWorkBook = oExcel.WorkBooks.Open('C:/test.xls')
oModule = oWorkBook.VBProject.VBComponents.Add(1)
sCode = 'sub VBAMacro()\r\nmsgbox "VBA Macro called"\r\nend sub'
oModule.CodeModule.AddFromString(sCode)
oExcel.Run('VBAMacro')
Pythonね
次はRubyあたりでお願い
どの言語でも一緒だろ
636 :
628 :2007/11/23(金) 23:14:05
>>629 0120,345が、120,345になるのでゼロサプレスされないようにしたいです。
で、,がそのままだと、区切り文字になってセルが変わってしまうので、
それも回避したいのです。
アドバイスありがとうございます。
ちょっとやってみます。
637 :
628 :2007/11/23(金) 23:23:42
マクロで記録してみましたが、 CSV上は、"0123,456"で保存されていますが、 表示はやはり120,345になります。 セルを文字列形式にして、入力してみましたが マクロの中身も打ったままになってます。 うーむ簡単なようで、難しいです…
拡張子をtxtに変えたか?
639 :
628 :2007/11/23(金) 23:53:01
>>638 開いたときにウィザード形式で選んで開けるのですが、
マクロを記録した状態で、txtファイルを開くと、
マクロにはBook1!Macro1と表示されるだけで、実行できません。
根本的にやりかたを間違っているのかもしれません。
Excelにまかせるとかなり勝手なことされるから 自前でテキストファイル開いてセルに流し込んでる
で、"0123,456"はセルに0123,456と表示されたのか? Yes→根本的にExcel Macroの使い方がわかってないから、これ以上俺からはアドバイスしない No→やり方が間違ってる。できるはず。だけどやっぱり俺からはもうアドバイス無しね。 じゃ、がんばって。
あーひとつだけ追加でアドバイスしとこう。 Excelのバージョン書かないと、やり方を教えようにも教えられないよ。
643 :
デフォルトの名無しさん :2007/11/24(土) 00:26:29
>>640 DBの項目をCSV形式で出力したものを、
エクセルで開いているだけなので、
出力時にエクセルで開いた時とテキストで開いたときの表示が
同じようにするしかないかな〜と思っています。
>>641 セルには123,456と表示されました。
マクロ使うのは初めてです。
保存先を変更したら記録を残せました。
ファイルをオープンした処理が残っているだけで、
出力に関する記録は残ってませんでした。
>>642 バージョンは2003です。
普通のやり方ではうまくいかないような気がするので、
もうちょっと考えてみます。
アドバイスありがとうございました。
日本語も勉強してこい
いや、普通にExcelでオープンすればできるから。 他の板にExcelスレないんか?
いや、ちょとまて。俺のは2007だから出来てるのかもしれんな・・・
とりあえず、俺の環境で記録したマクロ貼っとく。Excel2007な。 Sub Macro1() ChDir "C:\temp" Workbooks.OpenText Filename:="C:\temp\test.txt", Origin:=932, StartRow:=1 _ , DataType:=xlDelimited, TextQualifier:=xlDoubleQuote, _ ConsecutiveDelimiter:=False, Tab:=False, Semicolon:=False, Comma:=True _ , Space:=False, Other:=False, FieldInfo:=Array(Array(1, 2), Array(2, 2)), _ TrailingMinusNumbers:=True End Sub
ファイルの内容書き忘れた。 "012,345",1234 "123,456",2345
649 :
628 :2007/11/24(土) 10:23:33
2003だとこのようなマクロになっていました。 Sub Macro1() ChDir "C:\Documents and Settings\Owner\デスクトップ" Workbooks.OpenText Filename:= _ "C:\Documents and Settings\Owner\デスクトップ\Book1.txt", Origin:=932, StartRow:= _ 1, DataType:=xlDelimited, TextQualifier:=xlDoubleQuote, _ ConsecutiveDelimiter:=False, Tab:=True, Semicolon:=False, Comma:=False _ , Space:=False, Other:=False, FieldInfo:=Array(1, 1), _ TrailingMinusNumbers:=True Columns("A:A").EntireColumn.AutoFit End Sub 表示は2行で各行1セルでこのように表示されていました。 123,451,234 1,234,562,345 2007の試用版落としてできるか確認してみます。 お手数おかけしました。
650 :
645 :2007/11/24(土) 11:10:20
さて、Excel2000でもやってみたら、
>>647 と同じマクロになって、ちゃんとセルに012,345と
表示されたわけだが・・・。
どうやっても表示形式の問題としか考えられんのだが。。。
652 :
645 :2007/11/24(土) 11:31:31
あー、わかった。 データの形式を「文字列」に指定して無いでしょ。 マクロで言うと、FieldInfo:=Array(1, 1)の最後の1がデータ形式をあらわしてて、 文字列は、xlTextFormat(=2)を指定する必要がある。
ああ、そういうオチでしたか。 しかし、その程度のExcelの知識もマクロの知識もなく、調べ方もわからない奴がこの先どうやっていくんでしょうね。
何かある度にこういう掲示板で聞いては、教えたがりが出てくるのを待つんでしょ? w
まともな回答が一発で出てこないのが醍醐味ですな
つ、つられないぞ 俺はそんな質問には、絶対。。。
平日にばかり質問が集中してるのは 「これですか?ええ!プログラムしちゃいますよ!自分何でも出来ますから!」 とかデカいこと抜かして 「教えてください 大量にあるので終わらないんです・・」 と、ここで教えてくん そんな寒い背景を想像してしまいます(><
グラフのプロット点の右クリックからできる 近似曲線の追加って、多項式近似で7次以上やる方法ないのだろうか
あるよ やりかたは自分で調べてね
役に立たないスレw
そうでもないか
自分で最小二乗法実装すれば やりかたは調べたら簡単に見つかる
663 :
デフォルトの名無しさん :2007/11/26(月) 08:54:48
VBAできる? って聞かれて、 どの程度だったら出来ますって言って恥ずかしくないんでしょう?
その質問をした人にそう聞いてみればいいじゃん
回答者の質が低すぎる
と、放置されたクレクレくんは怨みを抱いた
>>666 × と、放置されたクレクレくんは怨みを抱いた
○ と、放置された日本語が変なクレクレくんは怨みを抱いた
>>657 別にそれでも全くかまわないけど、お前はかまうの?
結果出せばいいんです
ここまで俺の自作自演
671 :
デフォルトの名無しさん :2007/11/26(月) 19:30:05
WinXP, Excel2000 マクロを起動して Dim src As Range Set src = Sheets("Sheet1").Cells.CurrentRegion Set src = Sheets("Sheet1").Range("a1").CurrentRegion とすると、srcはどちらのSetでも意図したとおり たとえば、 $A$1:$C$2 のように設定されます。 しかし、自作関数を起動して同じコードを実行すると、 src.Addressは$1:$65536とか$A$1になります。 最初に起動したのがマクロか関数かによって結果が違っているようなのです。 関数起動で.CurrentRegionの意図した結果を得るにはどうしたらいいですか?
672 :
671 :2007/11/26(月) 19:42:08
関数起動の場合でも、マクロ起動と同じブックを見ていることは確認しています。 セルの値も合ってました。
673 :
デフォルトの名無しさん :2007/11/26(月) 19:57:18
(1) xp 2002 旧機 (2) xp 2003 比較的に新機 で、 同一のマクロを実行して(visible、 enableeventsはfalseにしている)、 (1)では6秒 (2)だと12秒 (エクセルのオプション設定も同一です。) どうしてこんなに、違うのか理由がわかりません。なにか、試してみることがありましたら、教えてください。
675 :
デフォルトの名無しさん :2007/11/26(月) 20:15:25
マクロは、計算はほとんどなく、条件判断とそれに応じた書き込みです。 calculationをfalseにしたら、その分、かえって遅くなったぐらいです。
んじゃ 書き込みが遅くなったんじゃね? 書き込みしないで比較したら? そんなに知りたいならいくらでも調べようがあるでしょ
677 :
673=675 :2007/11/26(月) 20:22:06
screenupdatingもfalseです。
>>671 再現する最小構成のブックをうp
>>673 マクロの内容を部分的に伏せたりせず全貼り(何レス消費してもいいよ
orブックごとうp
それが出来ないorしたくないならさようなら
比較的に新機 とやらのマシンのメモリが足りんとかの落ちじゃ?
680 :
デフォルトの名無しさん :2007/11/26(月) 20:31:15
>>678 手元にないので、今日はできない。明日気が向いたら、アップするかも。
>>676 中断させて、測ってみます。
681 :
673 :2007/11/26(月) 20:34:25
あっ、言われてみれば、その可能性があったです。旧機はメモリーを増やしていたw サンクス
エクセル以前の問題だな
683 :
671 :2007/11/26(月) 21:06:09
>680 アンタ何者? アップする場所がわからないので、ここに書いておきます。 ---標準モジュール----ここから Option Explicit Sub sample1() Dim src As Range Set src = Sheets("Sheet1").Cells.CurrentRegion Set src = Sheets("Sheet1").Range("a1").CurrentRegion End Sub Function fun1() As Integer Dim src As Range Set src = Sheets("Sheet1").Cells.CurrentRegion Set src = Sheets("Sheet1").Range("a1").CurrentRegion sample1 fun1 = 1 End Function Sub sample2() Dim r As Integer r = fun1() End Sub ---標準モジュール----ここまで set のところにブレークポイントを置いておく。 [Sheet1]の中身 A1:C2の範囲に、何か適当に数値を入れる。E5に =fun1() を入れる。 マクロsample1、sample2をステップ実行する。srcをsetしたところでイミディエイトウィンドウに ?src.Address を入力する。$A$1:$C$2となるのが、意図した動作。 E5のセルを編集して確定すると、fun1内でブレークする。 ?src.Address をしても、$1:$65536とか$A$1になる。sample1の中に入っても同様。
エクセルのバージョン違うなら当然なんじゃないかと。 気になるなら旧機に2003入れてやって見ろ。
今ひとつ何がしたいんだかよく分からんけど、 > E5のセルを編集して確定すると これじゃカレントセルがE5になるから、CurrntRegionが全セルになるんジャマイカ?
686 :
671 :2007/11/26(月) 22:47:05
>685 E5セルを編集するのは、関数を実行するためのひとつの方法です。 E5を編集しない方法で、関数を実行しても同じ結果になります。
何がしたいんだか皆目分からんし解読する気もないけど、とりあえずCurrentRegionに
こだわらずメソッド変えた方が良い
>>686
689 :
671 :2007/11/27(火) 07:57:38
関数起動とマクロ起動とで動作が違うと非常にやっかいなのです。 CurrentRegion以外にも動作が違うものがあるのか?とか 問題が発散してしまうのです。
関数起動とマクロ起動の違いが原因で起こってる動作の違いじゃないから
初心者な質問で悪いけど Range("A1:W引数")って感じに記述したいのですが可能ですか? 出来るなら引数部分の記述方法も教えて下さい
>>691 普通に文字列の連結でいけます。
Range("A1:W" & 引数)
あと、range(cells(1,1), cells(引数, 23))という書き方もできます。
> range(cells(1,1), cells(引数, 23)) をやるときは親に注意 初心者がよくやらかす間違いというか失敗です
worksheet.range(x1, y1, x2, y2)って書き方ができたら良かったのに。
シートオブジェクトとx1, y1, x2, y2を渡すとその範囲のRangeオブジェクトを返す関数でも作っておけばいいじゃん アドインなり個人用マクロブックなりに入れておけば、SONOPCでは汎用的に使えるし
main しか書いたこと nain です
697 :
デフォルトの名無しさん :2007/11/27(火) 18:33:32
前から、失礼します。 Range("A1:W" & 引数) という書き方は初めて見て、びっりしています。 後ろが出来たら、前も出来そうなんだけど、どう書いたらいいのですか。 今いろいろとやっていても出来なかった。 初心者の失敗とやらも教えてください。
>>697 それって1+2=を3と教えられて、じゃあ2+1=は?って聞いてる様なもんだぞ
答え(書き方)を聞くんじゃなくて、足し算(文字列の連結)について勉強しろ
>697 イルカチャンに 複数セルの文字列と数値の結合について 質問してごらん。どのようなことができるか、書いてあるよ。
Range(chr$(引数 + 64) & 引数 & ":" & chr$(引数 + 64) & 引数)
Range("A" & 引数 & ":W" & 引数)
702 :
デフォルトの名無しさん :2007/11/27(火) 20:17:41
次は 1+3 の計算だな w
Cells(1,1).Formula = "=1+3"
アドインに記述してあるマクロのキーボードショートカットを .xlaのままで指定することはできますか?
706 :
671 :2007/11/28(水) 19:32:51
なぜヘンな動作になるかサッパリわからないので マクロ起動でデータを設定したときにCurrentRegionして名前をつけ function起動時は名前を使うこととします
707 :
671 :2007/11/28(水) 21:10:32
別におかしな現象が起こりました。.findメソッドは、関数起動だとNothingしか返しません。 関数起動だと、セル関係の便利機能は使えないのですか? そんな制限に関する解説はどっかにありませんか? 発生する例をあげておきます。 シートのA1:A9に1,2,3,4,....と入れておく 標準モジュールはじめ Option Explicit Function func1() Dim found sub1 Range("A1:A9"), found, 4 func1 = 1 End Function Sub sub1(r As Range, found, value) Set found = r.Find(value) End Sub Sub substart() Dim found sub1 Range("A1:A9"), found, 4 End Sub 標準モジュール終わり 適当なセルに=func1() として関数起動した場合と マクロsubstartを実行した場合とで、.Findの結果が違います。
ああ気持ち悪い
そもそもマクロも関数が実行されるわけだが 関数起動ってのはいったいなんだ?
セルに=関数() って入力するやつだろう 本能的にvbaにワークシート関数混ぜるのは避けていたが 正解だった
>>707 2007でやってみたけど挙動は同じ
とりあえず、おかしな現象とか決めつけないで、
まずはRangeの前のシートを省略してたりするおかしなソースから直したらどうか
712 :
671 :2007/11/28(水) 23:55:18
>711 簡単のためにシートを略しただけであって、シートをつけても同じです。 .Findのところを Dim ofst ofst = Application.Match(value, r, 0) Set found = r.Cells(ofst) としたら、関数起動とマクロ起動が同じ動作になりました。。 XP SP2、Excel2000です。
>>712 シート略したらアクティブシートが変われば結果がかわるじゃないか
両方の動作が同じかどうか本気で検証したいのなら、
操作手順などで結果が分からないようにソース書きなよ
×結果が分からないように ○結果が変わらないように
715 :
671 :2007/11/29(木) 00:20:09
いきなり汎用化して考えず、まずはひとつのシートのみが存在するブックで考えています。 ステップ実行して、Rangeオブジェクトのaddressやvalueが同じであることも確認しています。 しかし、.Findの結果が異なるのです。
716 :
デフォルトの名無しさん :2007/11/29(木) 00:26:03
任意の文字数の文字型変数aaがあって、aaの右側2文字が G2という文字の場合、その文字を除いた文字を表すようにしたい。 範囲Rの中でやるので、動作が早い文を書きたい。
IIF(Right(aa,2)="G2",LEFT(aa,LEN(aa)-2),aa)
>>715 VMwareにXP SP2とExcel2kだけ入れてやってみたら、確かに同じ現象になったよ
原因は分かんないけどOfficeのSPとかあててみたらどうだろうか
単にセルが編集モードになって一部機能制限があるとかなのかもしれんけどね
>>717 それはかなり遅いと思う・・・
こう書くだけで倍くらい早くなるよ
If Right$(aa, 2) = "G2" Then
変数 = Left$(aa, Len(aa) - 2)
Else
変数 = aa
End If
720 :
671 :2007/11/29(木) 02:10:19
>719 ありがとうございます。 関数起動の場合は、input以外のセルは見ないほうがいいのですね。 ということは、今動いているように見えるinput以外のセル参照も止めたほうがいいですね。 inputのRangeに対しては、.Findは使えるのかな? .CurrentRegionの結果を含有するような範囲をinputに入れれば.CurrentRegionは使えるのかな? 実験して後で報告します。
721 :
691 :2007/11/29(木) 09:40:46
回答してくれた人達、ありがとうございます。 もう一つ気になったのですがフォームに配置したテキストボックスとかにインデックスはつけられないんです
>>720 > 実験して後で報告します。
いや、もういいから。
結果は君の心の中に・・・。
723 :
デフォルトの名無しさん :2007/11/29(木) 11:11:33
文字列群の中から、特定の文字を含む文字列を検索するのは Likeでいいのでしょうか?
それでもいいけど、instrという関数も用意されてる
725 :
デフォルトの名無しさん :2007/11/29(木) 12:59:11
>>724 If InStr(xxx, "x") > 0 Then
ですね?
ありがとうございます。
726 :
デフォルトの名無しさん :2007/11/29(木) 18:57:16
checkMsg.okMsg = Range("A1").Value 上みたいに、変数同士を、ピリオドでくっつける(?)のは 何でググったら分かりますか。名称とか使い方とか・・・
>>726 おそらくcheckMsgとokMsgの両方に同じ値を入れるのを
1ステートメントでやりたいんだろうけど、そういう構文はVB、VBAには存在しないよ
存在しないんだから、何でググっても無駄
checkMsgが親(Classとか)でokMsgがプロパティだってなら話は別だけど
728 :
デフォルトの名無しさん :2007/11/29(木) 19:10:20
>>727 ありがとうございます
ちゃんと動いているからw、後者っぽい・・・
CSVを取り込んで、シートに並べるプログラムなんですよね
変数に代入されてる値はなに?
>>726 ユーザー定義型
他言語で言うところの構造体
新規にワークブックを作成するとき、 Set (オブジェクト変数) = Workbooks.Add とすると、(オブジェクト変数)で操作できるけど、 既にあるExcelファイルを、(オブジェクト変数) にしたいときはどうすればいいの?
thisworkbookやらactiveworkbookやら Workbooks("hoge")やら
733 :
716 :2007/11/30(金) 01:30:58
>>717 >>718 サンクス。昨夜は寝てしまったw
お礼を兼ねて、以下、折れの意見
iif文は10年以上前、dbxlだったか、lotusかexcelであったかわからないが、よく使っていた。
今年、久々にexcelを扱うようになって、調べて、iif文は使えない(使われていない)ものと思っていた。
iif文を使えるためには入れ子でエラーを発生させない論理力が特に大事だが、入れ子が深くなるほど、if文より早いため、高速if文と呼ばれていたよw
今回、for each文で、2万セルで試して見た。セル状況にも寄るが概して、iif文の方がif文よりも少し早いと言えるね。
734 :
デフォルトの名無しさん :2007/11/30(金) 02:03:56
質問です。 ◆やりたいこと 下記関数に、仮にA1:D10範囲のグラフデータを渡すとした場合 関数内部でA1:B10とA1:C10とA1:D10と1行づつずらして 複数の散布図を作成したい ◆わからないこと rangeから1行取得し、ずらすというやり方がわからず、 下記コードの?の部分をどうするか悩んでいます。 宜しくお願いします。 function グラフ作成(rng as range)as boolean 'rangeから for i=0 to ? range1=? range2=? union(range1,range2) '散布図作成(省略) next i End Function
735 :
デフォルトの名無しさん :2007/11/30(金) 02:49:05
>>729 代入する値は自由に設定出来る。
んで、代入した値がinputしたcsvに有るか無いかで
そのcsvの素性を判断するような感じ。
>>733 IIFのほうがIFより遅い
セル状況にもよるとか意味不明
そもそも階層なんてなるべく浅くするもんだが
738 :
734 :2007/11/30(金) 08:58:37
>>734 わかりずらかったので加筆します。
Rng=Range(A1:D10)から
Rng1=Range(A1:A10)を
一行だけ取り出す方法はあるのでしょうか?
もしなければ他の方法があれば教えてください
739 :
デフォルトの名無しさん :2007/11/30(金) 09:58:28
ユーザー定義変数+二次元配列 これをがんばって(`・ω・´)習得する。
>>738 range("A1:D10").columns(1)
741 :
デフォルトの名無しさん :2007/11/30(金) 11:34:43
Dim A() as variant Dim a as intger Dim x as integer ReDim A(x) as variant x=0 a=1 Do while cells(a,1) <> "" A(x)=cells(a,1).value x=x+1 a=a+1 Loop cells(5,5)=A(x)+A(x-1)+A(x-2) とやりたかったのですが、 A(1)になった時にA(0)に入った値が消えています。 どこが間違っているのか御教示ください。 よろしくお願いします。
743 :
デフォルトの名無しさん :2007/11/30(金) 13:28:44
>>742 ありがとうございます。
自力で少しずつ直しています。
Dim A() as variant
Dim a as intger
Dim x as integer
x=0
a=1
Do while cells(a,1) <> ""
ReDim Preserve A(x)
A(x)=cells(a,1).value
x=x+1
a=a+1
Loop
こんな感じで実物はうまく回るようになったと思います(ミスはまだありそうですが)
あのさー、VBAのエディタからコピペしろよ。 それとoption explicitもしろ
745 :
デフォルトの名無しさん :2007/11/30(金) 14:11:57
英語の大文字、小文字って使い分けられるんでしたっけ。 まぁintgerは、ペタバイトの容量を扱える超変数定義だけど
しかしVBAのエディタっていつまでたっても進歩しないな
VisualStudioはタブ付いたり、関数折畳んだり出来んのに
VBAときたらいまだにホイールころころも出来ないとか・・・
>>743 最低限、コンパイルが通るソースを示しましょう
メニューの[デバッグ]→[VBAProject のコンパイル]を選択すれば確認できます
mousewheel fixくらいは、デフォルトでfixしとけってことだな
748 :
デフォルトの名無しさん :2007/11/30(金) 20:13:25
>>740 >
>>738 > range("A1:D10").columns(1)
ありがとうございます。
しかしうまくいきませんでした。
列番号が返ってくるみたいです。
>>739 その方法も考えましたが別の問題がありやめました。
そるはRangeではなく、配列データから、グラフを描けるやり方がわからないのです。
できれば簡単そうなRangeで解決できればと考えています。
>>748 返ってくるのはrangeだよ。
「列番号」って何だよ。
なんか同じような質問が多いな。 unionなんか使う必要ないんじゃね?ダイレクトに始点と終点を指定してrangeを作れよ
751 :
デフォルトの名無しさん :2007/11/30(金) 21:08:05
コンパイルでエラーがでるのでヘルプをみたのですが、勘違いみたいです。 A1:D10からA列とC列のような飛び飛びの列からも散布図を描きたいので。 あとできるかぎり関数内で閉じていたいので関数へ引き数でRangeを渡して内部で計算したいのです。 なのでrng=Range("A1:D10")を引き数で渡して、 内部でSet rng1=Range(UNION(Range("A1:A10"),Range("C1:C10")))範囲をグラフデータにセットしたいのです。 そのためにRange("A1:A10")の一列をrngから取得したいと考えています。
もやは、釣りなのか何なのかわからなくなってるが。 VBAのIDEでCtrl+Gしてから次のコードを実行してみろ。 Set Rng = Range("A1:D10") Set Rng1 = Rng.Columns(1) Set Rng2 = Rng.Columns(3) Set Rng3 = Union(Rng1, Rng2) Debug.Print Rng.Address Debug.Print Rng1.Address Debug.Print Rng2.Address Debug.Print Rng3.Address
>>752 できました。sを付け忘れていました。ありがとうございました
初心者のお願いで大変恐縮なのですが、次の動作をするためにはどのようなマクロを組めばよろしいのでしょうか? どなたか御教示いただけませんでしょうか? 1.A列各行にあ入力済みの数値(入力数はデータにより一定ではない)を B列とC列とを結合したセルにコピー(表の体裁上、結合しています) 2.コピー先の行間は表の関係から8行ずつ空ける 3.この一連の動作を行う回数はA列に値が入っている数とする(=count(A:A)) 今までは回数指定もできず、下記の超初心者な式を必要分だけコピー、修正していたのですが データ数が多い場合、この修正作業自体がミスを誘発してしまうので、もっと機械的に 処理できるようなマクロを使いたいと思っています。 Range("A1").Copy Range("B1:C1") Range("A2").Copy Range("B10:C10") Range("A3").Copy Range("B19:C19") ・ ・ ・ 私の能力では、本を見てもネットで調べてもわかりませんでした。 どうぞよろしくお願いいたします。
755 :
754 :2007/12/01(土) 15:45:16
スミマセン。↑ A列各行にあ入力済み→A列各行に入力済み です。
756 :
731 :2007/12/01(土) 16:05:50
a=要素数をセット b = 1 for j=1 to a Range( "A" & j ).Copy Range("B" & b , ":C" & b) b = b + 9 next
>>757 > Range( "A" & j )
質問者ではないが横から失礼。
これいつも困るんだけど英語の部分が変数のときはどうしていますか?
cells(j,k)
760 :
デフォルトの名無しさん :2007/12/01(土) 18:01:57
>>754 値だけでいいならB1:C1に =OFFSET($A$1,(ROW()-1)/9,0) って入れて
B1:C9を選択してフィルコピーすれば済むと思うんだけど
どうしてもVBAで書式までコピーしたいならEndプロパティ使ってA列のデータ末尾取得して
その範囲に対してFor Each回し、初期値を1にした変数使って
Cells(変数, 2).MergeAreaにコピーした上で、変数の値を9増加してやればいいだろ
これで解らないようなら
>>2 ★5ね
>>758 Dim hoge As String
hoge = "A"
Range(hoge & 1)
とか?
763 :
754 :2007/12/01(土) 20:09:56
>>762 変数に、Aとかでなく数値でもってるとき。
具体的な書き方がわからず悩んだことがあって。
真に受けないように
昔Niftyで配布されてた、お宝ファイルって誰か持ってませんか?
持ってるかどうかは解らないが持っていたのは確か 削除した記憶はないから何処かに残ってるだろうが 探すの('A`)マンドクセ 少なくとも内蔵HDDには入ってないだろうから
771 :
デフォルトの名無しさん :2007/12/02(日) 03:43:08
質問です。よろしくお願いします。 excel に対しADOで接続したとき、そこでデータベース的にデータをadd/updateできるのは 普通の使い方ですが、このときデータではなく、関数を挿入することって出来ますか? 普通ならformula関数で関数をセットするところを、ADO経由で行うことが出来ますか?という質問です。 。
Function プロシージャを使いなさい。
774 :
デフォルトの名無しさん :2007/12/02(日) 10:44:52
>>773 つ Chr(変数1 +64) &Chr(変数2 +64)
ダメすぎ。
>>771 自己レスです。ADOだけでは無理だとしても、
excel側に、"="で始まる文字列データを見つけたら関数につっこみ直すというプロシジャを用意しておき、
ADOでとりあえずいったん"=..."の関数を意味する文字列を作って、それを文字列データとして
フィールドにセットしてから、用意したプロシジャをたたけばいいのかなと考えました。それでやってみます。
> 普通ならformula関数で関数をセットするところを いや、普通じゃないから 普通はRange(Cells)オブジェクトのFormulaプロパティを使うから ADOを使う意味なんて全くない、どころかデメリットしかない
>>767 昔のお宝なんて今は常識みたいなものだから、分かってる人には必要ない。
俺の書き込みもお宝に多数取り上げられたが、今では全然たいしたことないテクニックばかり。
>>773-775 つ IIf(変数 > 26, Chr(CInt((変数 - 1) / 26) + 64), "") & Chr(((変数 - 1) Mod 26) + 65)
>>778 特定されるからどの章かは言わないけど、かつてとある章を編集してどんな内容だったか
見たいんです。
この間、HDDが壊れて、このスレ読んでてバックアップしたCD-R読もうとしたら読めなかったorz
ファイルを保存していたHDDが壊れて、そのファイルの存在を忘れてたので気にならなかったんですが、 このスレを読んでいてその存在を思い出して、バックアップしたCD-Rから読もうとしたけど読めなかったんです。
いや、だから日本語で(ry
786 :
exc :2007/12/03(月) 07:20:43
自分が読めなかったからだろ。 書くほうも読むほうも語学力無さ過ぎだな。哀れ。
バックアップしたCD-Rが読めなくなっていてリストアできないから、 誰かファイル持ってませんかってことだろ。
当時参加してた人にお願いしてみるとか。 Office Tanakaの中の人とか。
あー、俺も持ってた(けど、どっかいった) MS Help形式で結構便利だった気がする
>かつてとある章を編集してどんな内容だったか見たいんです。 日本語で(ry >このスレ読んでてバックアップしたCD-R読もうとしたら読めなかったorz 日本語で(ry
なんで粘着してんだこいつ
質問があります。以下のようなプログラムがあるのですが、 この場合のWithってどういう意味なのでしょうか? With Range("a1") Do If F = False Then Exit Do i = (i + 1) Mod 10 .Value = i DoEvents Loop End With 実行すると、A1にiの値が表示されます。 Range("B5").Value=i と同じ意味になるのでしょうか? なぜ、Withを使うのでしょうか?
もしかしてキャッシュしてるのかなあ 一旦Range("a1")を変数に代入するのと同じなのか、 Range("a1").Valueと毎回指定するのと同じなのか 実際どっちなのかは知らないから俺も教えてほしい
>>793 read the fucking manual
797 :
796 :2007/12/03(月) 16:56:49
持ってるはずだけど、見つからなかったのでうp断念
With Range("a1") → .Value = i End With withは記述を簡略化できる。 本来 Range("a1").Value = i と書くべき所、withからEnd Withの間は .Value = i と書くだけでおk Range("a1")の分書くのが楽になったんだぜ☆(ゝω・)v
速度が早くなる。 『高速化 VBA』 で検索したらいろんな方法が学べるよ
800 :
793 :2007/12/03(月) 18:54:43
まぁ、そういう意味じゃ>794の前者だな。
set r = Range("A1") r.Value = i とどちらが速いですか?
試せよ
ここの質問者は、自分で出来ること(試せること、調べられること)すら やろうとはせず、「調べても解りません、困ってます」とか言い出す
1文字変数は馬鹿の所業
どうしてレベルの低い奴しか来なくなったんだろう
RTFM
811 :
デフォルトの名無しさん :2007/12/03(月) 22:04:32
2007つかえねー
812 :
デフォルトの名無しさん :2007/12/04(火) 09:03:23
下記グラフの生データからVBAのみで度数分布図を作成したいと考えています。 区間0.000〜0.400、区間数n=4として Data(2,10)AS Variant rng AS Range gdata(4,2)AS Variant rng=Range("A1:B10") Set Data(2,10)= rng '←@この代入は可能ですか? (ここでいろいろ計算した結果下記のグラフ作成データが得られるとする) gdata=Array({0.000,0.100,0.200,0,300},{1,3,4,2}) Chart.Add 〜Source gdata '←Aグラフデータ設定方法はRangeでなくても可能ですか? 以下Chart.Typeを棒グラフに設定 〜〜 ------- Range("A1:B10")の範囲に 選手,打率 松井,0.352 古田,0.221 新井,0.153 間中,0.262 亀井,0.301 田中,0.192 萩原,0.153 喪菜,0.082 田淵,0.274 井坂,0.225
配列への代入は、配列へのポインタを示せばいい Data = rng.value
>>806 お前時代遅れのハンガリアンとか使ってない?
あとコメントもだらだらと毎行書いてそうだなw
一文字変数くらいで読みにくくなるような長い関数を書くのが間違い
iがIntegerなのは普通 rがRangeなのも普通
グローバル変数に3文字省略名とか付ける奴は死刑
for each c in r
819 :
デフォルトの名無しさん :2007/12/04(火) 17:53:15
r でなく、rng の折れは死刑かwww
>>814 JAVAみたいになんでもクラスな言語でハンガリアンの型表現は意味ないが
VBAでハンガリアンが時代遅れとか関係ないだろ
時代遅れって・・・流行りでやってるとでも思ってんのかよw
カスコーダーがいくら力説したところで、コーディング規約を考えてないヤツはカス しかも正当化にまで至ってるのはカスを越えてクズだな
822 :
sage :2007/12/04(火) 18:46:15
SolverのShowRef(マクロ実行)って死んでるの?
%&@!#$
>>820 クラスの中はふつーJAVAでもハンガリアンだろ
一文字変数だがiとかcは普通だしExcel VBAのヘルプでも使ってるぞ? オマイは For lngCounter = 1 To lngLastRow などとやりそうだなw
>>821 俺はそこらのカスとチームは組まないからコーディング規約などない
一人で勝手に作って納入してる
827 :
デフォルトの名無しさん :2007/12/04(火) 20:41:49
VBAをチームでコーディングw 釣りだとしてもおもしろすぎ
規模次第で珍しくもないが
829 :
デフォルトの名無しさん :2007/12/04(火) 20:51:51
はいはい、すごいねー わざわざVBAでコーディングすることもあるよねー
客がデータ加工されてるシート欲しがるんだから わざわざもないだろw
831 :
デフォルトの名無しさん :2007/12/04(火) 21:04:35
Month(Date)、Day(Date)から文字として、5月4日の場合、05や04をを得るにはどう書けばいいですか。
format で mmやddにして、さらに Cstr で文字に
俺もよくチームがコーディングでVBAしてる 欲しがるから仕方ない
834 :
デフォルトの名無しさん :2007/12/04(火) 21:16:57
ま、可読性を考えずにコードを組むやつに利口なやつはいない これだけは真理だな
下層のプログラマーの愚痴だろどうせ 楽できるからな
>>827 最下層の会社にしかそんな依頼は来ないが
そういう依頼が来ることがあるのは確かだよ
Accessあたりじゃチーム案件も珍しくないけどな
俺もよくチームがコーディングでAccessしてる 珍しくないから仕方ない
自分のやってることは珍しいことではない そう思い込んで安心したいのは人間の真相心理です その逆で、人とは違うことをしたいという心理も、主に幼い頃や若い頃にはありますが
あほだなむしろコーディング効率のいいVBAのほうが 大きな仕事に向いてるだろ 小さなプログラムの最適化は他の言語だろうが
>>841 CStr(Format(Day(Now()), "dd"))は駄目?
Format$(now(),"mm") Format$(now(),"dd")
844 :
831 :2007/12/04(火) 22:57:44
>>832 さんへ
お礼に出来たものを書きます。
いろいろやってみて、最終的なものと思います。
Format$(Date,”mm dd”)
これで、今日なら、12 04と返してくれます。
いろんな応用を調べていました。おもしろいです。
質問です ユーザーフォームへのドラッグ&ドロップでファイルパスを取得するやり方を教えてください
VBAはパーソナルユースだと思ってた。
>>846 無茶させようとする人がいるのと、実際に無茶できるのが
悲劇の始まり。
>>834 よくコメントを書きまくれば可読性が上がると思い込んでるアフォがいるよな
コメントは少ない方が可読性は上がるということが分からないらしい
レベル低すぎー
>>848 ケースバイケースだな
ビジネスロジックの部分にコメント入れないのはダメダメだ
スレタイ嫁
2つのシートを比較して吐き出そうとしてるんだけど、怒られる。 Sub conpare() Dim fromRange As Range Dim toRange As Range For Each fromRange In Worksheets("Sheet1").Range("E5:E132") For Each toRange In Worksheets("Sheet2").Range("A1:A43") If StrComp(fromRange.Value, toRange.Value, vbTextCompare) = 0 Then Cells(fromRange.Row, 6).Value = "○" End If Next toRange Next fromRange End Sub For Each fromRange In Range("E5:E132") は通るんで、Worksheetsの使い方が悪いんだろうけど、良く分らん
・compare ・誰にどう怒られるのか ・要求仕様を明確に
そりゃあんた、その辺で吐き出そうとしているんだから掃除のおばちゃんに怒られるんだよ。
すまん。自己解決。 Worksheets("Sheet1") sheet1に名前付けてたからそっちの名称じゃないと見つからんのな
(/∇≦\)アチャ-!ミテランナイ
自分の恥ずかしさが?
858 :
デフォルトの名無しさん :2007/12/06(木) 14:59:15
デバックで、ステップ実行した時とそれ以外では結果が違うのです。 ステップ実行:きちんとセルに値が入る 普通に実行:セルは空欄のまま プログラムには触っていませんがこのように結果が変わってきます。 どのような原因が考えられますか?
考えられません
>>858 その説明、漠然としているので原因なんて推測できないっすね。
多分なんかすっとぼけてるだけのような気がしますけど。。。
解決したらちゃんと教えてくださいね。
861 :
858 :2007/12/06(木) 15:42:37
わかりました。 漠然としてて申し訳ないです。 原因はExcelシートを指定してなかった為でした。 cells(x,y) ↓ objExcelSheet.cells(x,y) で思った通りに動いてくれました。 ありがとうございます。
過去数年間の見積りをEXCELでデータベースにしてあるのですが、リンクが無く いくらデータベース化してても、結局サーバ内のファイルを手動で見に行くようになっています そこでハイパーリンクを使ってセルクリックで開くようにしたいのです サーバには↓のような感じで保存されていています \\鯖\見積り\○×商事\H19年\ABC-001 複合プリンター一式.xls 今までのは手動でいれるしかないとしても、今後は登録する時に一緒にリンクをはっておきたいのです つまり登録する時にあるセルに =HYPERLINK("ファイルの保管場所",開く) と記入したいのですが、いちいちファイルのプロパティから保管先をコピーするのが辛く… VBA等でそういうのを入手する方法は無いでしょうか? (ファイルを開くみたいな動作で保管先をクリップボードに読み出せるだけでもOKです)
説明がドヘタすぎて理解できん
864 :
デフォルトの名無しさん :2007/12/06(木) 18:23:16
書くなら、理解できないことを書いてみればよいのにwww
Dim あ As String Dim い As String Dim う As New DataObject あ = "Excelファイル (*.xls),*.xls,CSVファイル (*.CSV),*.CSV,テキストファイル (*.TXT),*.TXT" い = Application.GetOpenFilename(あ, 1, "ファイル名取得") If い = "" Then Exit Sub With う .SetText い .PutInClipboard End With >(ファイルを開くみたいな動作で保管先をクリップボードに読み出せるだけでもOKです) はいはい解決解決
コマンドボタンを押すとテキストボックスに入力された数字を読んで、 判定結果をラベルに表示するというプログラムを作りたいのですが、 テキストボックスの入出力やラベルへの入出力の文がわかりません。 調べ方が悪いのか、自分で解決できなくて困っています。 どなたか教えていただけませんか? だらだらとわかりにくくてすみません。
867 :
866 :2007/12/06(木) 20:00:16
変数 = TextBox1.Value で数字を読めることがわかりました。 Range("a1").Value = 変数 で変数の値を表示させたらテキストボックスに入力した まま表示されたので、よかったです。 引き続きラベルに表示させようとしていますが、 Label1.Value = 変数 では「プロパティかメソッドをサポートしていません」と言われます・・・。 もうちょっと色々試してみます。
868 :
デフォルトの名無しさん :2007/12/06(木) 20:16:46
ファイルAがアクティブならば次の作業へ 開いてなければファイルAを開く という文章が上手くいきません。。 教えてください、お願いします。
これはひどい
>>867 LabelはCaptionだろ。インテリセンス使え。F1押せ。ヘルプ見ろ。
>>868 アクティブって何だ?誰がアクティブにするんだ?
ファイルAが開いてない状態でマクロを実行すると 処理前にファイルAを開く でいいんじゃないかな
誰がおーぷんするんだよ?
conpareの人です。 Sub compare() Dim fromRange As Range, toRange As Range, Str As String, flag As Boolean For Each fromRange In Worksheets("Result").Range("E5:E132") flag = False For Each toRange In Worksheets("sheet1").Range("A1:A43") If StrComp(fromRange.Value, toRange.Value, vbTextCompare) = 0 Then flag = True End If Next toRange If flag = True Then Cells(fromRange.Row, 7).Value = "○" Else Cells(fromRange.Row, 7).Value = "×" Next fromRange End Sub Sub compare2() Dim fromRange As Range, toRange As Range, Str As String, flag As Boolean For Each fromRange In Worksheets("Result").Range("E5:E132") flag = False For Each toRange In Worksheets("sheet2").Range("B1:B80") If StrComp(fromRange.Value, toRange.Value, vbTextCompare) = 0 Then flag = True End If Next toRange If flag = True Then Cells(fromRange.Row, 8).Value = "○" Else Cells(fromRange.Row, 8).Value = "×" Next fromRange End Sub
>>868 もっと句読点を使ってみたらどうでしょう
この2つをまとめる事って出来るでしょうか?
金玉のこと?
877 :
866 :2007/12/07(金) 00:54:18
>>870 出来ました!ありがとうございました!
ヘルプも見るくせを付けていきます、重ねてありがとうございました。
自己解決 Dim tempRange(2) tempRange(1) = Worksheets("sheet1").Range("A1:A43") tempRange(2) = Worksheets("sheet2").Range("B1:B80") て出来ますね。これでまとめる事が出来ました
で、今度はワークシートでなく、出力されたcsvデータで比較しようとしました。 csvをワークシートとして開けた場合、展開されるのはsheet1が暗黙の了解だろうと set tempRange = workbooks("temp.csv").Sheets("sheet1").Range("A1:A700") と設定したのですが Sub compare() Dim fromRange As Range, toRange As Range, tempRange As Range, Str As String, flag As Boolean workbooks.Open Filename:="D:\temp.csv", Format:=1 ⇒set tempRange = workbooks("temp.csv").Sheets("sheet1").Range("A1:A700") For Each fromRange In Worksheets("Result").Range("E5:E132") flag = False For Each toRange In Worksheets("sheet2").Range("B1:B80") If StrComp(fromRange.Value, toRange.Value, vbTextCompare) = 0 Then flag = True End If Next toRange If flag = True Then Cells(fromRange.Row, 8).Value = "○" Else Cells(fromRange.Row, 8).Value = "×" Next fromRange と、すると⇒で「インデックスが有効範囲にありません。(Error 9)」と怒られます 開け方悪いですかね? set tempRange = workbooks("temp.csv").Worksheets("sheet1").Range("A1:A700") でも怒られましたし、良く分らんです
csvファイルを開いたときのシート名はファイル名(のベースかも)じゃなかった?
うぜー マクロを記録しながらマニュアルで操作して、どんなコードが生成されるか観察しろ
882 :
デフォルトの名無しさん :2007/12/07(金) 18:43:42
ActiveSheetでいいんじゃね?
シェルとセンドキーを使ってアプリを起動してますがメモ帳とかで日本語切り替えやファンクションなどのボタンは入れられますか?
もはや何でもありかいな
885 :
デフォルトの名無しさん :2007/12/08(土) 00:32:10
高校の授業でわからないところがあるのですが、 * ** *** **** ***** ↑のようなメッセージボックスを表示させたいとき、 Sub ex_1() ←タイトル a = "" ←空のaの箱をつくる For i = 1 To 5 ←iの値の範囲を指定 For j = 1 To i ←jの値の範囲を指定 a = a & "※" ←? Next j ←次のjへ a = a & vbCrLf ← a を aと 改行にする Next i ←次のiへ MsgBox a ←iをメッセージボックスに表示 End Sub とある(矢印は自分のメモです。)のですが、5行目の意味がよくわかりません。 5行目の時点で、aという箱はどうなっているんでしょうか?? また、 i と j は a に関わってないように思えるのですが、どうしてaの行数・文字数が i と j で決まるのでしょうか?
>>885 最初aの箱は空の状態
iの一回目のループで、
jは一回ループする。
aの箱には※が入る。←質問の答え
改行
iの二回目のループで、
jは二回ループする。
aの箱には※が二回入る。
改行
・
・
・
以下五回目まで続く。
ああありがとうございます! a & "※" は a と ※っていう意味じゃあなかったんですね。 これで徹夜せずにすみそうです。
2重ループさせる意味が全くない Dim strChr As String Dim intCnt As Integer For intCnt = 1 To 5 strChr=String(intCnt,"*") & vbCrLf Next Msgbox strChr
まちごうた × strChr=String(intCnt,"*") & vbCrLf ◎ strChr=strChr & String(intCnt,"*") & vbCrLf
= は数学で言う"等しい"じゃなく代入するという事だと真っ先に習いそうなもんだが
その真っ先の話じゃないのかな?この例文は
高校でVBAやるのか 先生もよく解ってないんだろうな
それにしても現場じゃ使うことのないロジックで授業すんなよ先生!って言いたくなる例文だな
ループの練習でしょ BASICの代わりなんだろう
デメリットだらけの1文字変数の発生地は高校だったのか(~ε~;)
一文字変数だがiとかcは普通だしExcel VBAのヘルプでも使ってるぞ? オマイは For lngCounter = 1 To lngLastRow などとやりそうだなw
慣習を理由に思考思索を放棄してる低偏差値のカスに言うことは何もございません(~ε~;)
すいません シートネーム"シート1"が、あるとき For ii = 1 To Worksheets.Count sheet = Worksheets(ii).Name If (sheet = "シート1") Then : End If Next で変数sheetが"シート"になって (sheet = "シート1") がOKになるんですが シートネームに、日本語+数字をつけるのはいけないんでしょうか。
「シート1」の「1」が全角か半角かって話じゃね?
これNGにした→(~ε~;)
902 :
899 :2007/12/08(土) 14:17:17
>>900 すいませんでした。
変数名がまちがってました。
反省
903 :
デフォルトの名無しさん :2007/12/08(土) 17:13:17
質問です。
Excel2003でIE6をVBAで操作しています。
Set objIE = CreateObject("InternetExplorer.application")
strURL = "
http:// ・・・・
objIE.Navigate strURL
MsgBox objIE.Document.all(1).innerHTML
こういった感じでソースHTMLを確認しているのですが、
HPが表示されJavascriptで書き換えられている前のHTMLしか確認できません
ローカルウンドウで表示される他のDocumentも探ってみたのですが
どうも旨くいかず見つかりません。
書き換えられた後のHTMLデータを取得したいのですがヒントを御願い致します。。
objIE.Visible=True
objIE.Navigate strURL ここでdocumentcompleteを待ってないせいじゃないのか? MsgBox objIE.Document.all(1).innerHTML
コマンドボタンを押す度にコピー元が5行ずつ移動していくようにしたいのですが、 下記の構文では1回の移動しかしてくれません。 どなたか正しい構文を御教示願いないでしょうか? i = 5 Range("A4:A8").Copy Range("B4") Range("A4:A8").Offset(i, 0).Copy Range("B4") i = i + 5
i を sub の外に
釣りにマジレス
>>907 sub の外に出しても、コマンドボタンに割り当てられたマクロを抜けたら
値が保持される保証はないので、偶然でも動けばいい人以外はNG
Public i as Long
iなのにLong(笑)
>>912 910の案は間違っているからどうでもいいとして
i は Integer でも int でもなく Index のことだから型は関係ねえぞ
もともとはintegerだし、Cとかでlong iとかやると変
>>914 なんつーかそこまでして変数名を1文字にする意味がないと思うのは気のせい?
日本語でOK
>>915 気のせいじゃない
というか、誰も変数を1文字にする必要があるとか意味があるとかなんてことは一言も言ってない
単に状況によっては1文字変数にも不都合はないというだけの話
そだね。For Nextのカウンターはiが普通 ハンガリアン狂いはリストでも聴いてなさい
てっきりFor Nextかと思ったらそうじゃなかったか
920 :
デフォルトの名無しさん :2007/12/10(月) 15:21:31
すいません、ちょっと質問させていただきます。 ワークシート別に異なる編集処理を、同じ書式(同じメソッド名)で呼び出そうとしています。 現在、以下のように、Implementsを使用しようとしていますが、上手くいきません。 -ClassIF.cls- (PublicNotCreatable) Public Function GetTestString() As String End Function -Sheet1- Implements ClassIF Private Function ClassIF_GetTestString() As String ClassIF_GetTestString = "てすと" End Function -ThisWorkbook- Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range) Dim TestIF As ClassIF Set TestIF = Me.Worksheets.Item(1) MsgBox TestIF.GetTestString End Function
921 :
920 :2007/12/10(月) 15:24:16
(920のつづき) 上記のコードだと、コンパイルは通りますが、実行時に 「型が一致しません」 とエラーとなるので、 > Dim TestSh As Sheet1 Dim TestIF As ClassIF > Set TestSh = Me.Worksheets.Item(1) Set TestIF = Me.Worksheets.Item(1) とすると、一旦エラーとなりますが、ステップ実行を継続すると以降は動くようになりました。 情けないのですが、何をどう間違えているのか、判断が付きません。 目的は、多数のシートの処理を同じ書式で呼ぶことです。 (シートが多く、今後メソッドも増加することが予想されるので保守性を高めるため。) また、試しに、CallByName(Me.Worksheets.Item(1), "OwnerStr", VbMethod) を試したところ、 「メモリが不足しています。」 となりダメでした。(Public Function OwnerStr() を追加。端末メモリは1G) 環境は、WinXP SP2 + Office2003 VBA:6.4.8869 です。 なお、開発環境の制約上、VBが使用できません。 何らかのアイデアを頂ければ幸いです。
良くわからんけど、set testif=shとやったらちゃんと動いたぞ
>>922 ありがとうございます。こちらでも試してみたのですが、動いたり動かなかったりです。
こちらの環境では、初めは動いても、ファイルを保存して開きなおすと動かなくなります。
しかも、そうなると、再び動くようにするにはどうすれば良いか分からなくなってしまう状況です。
Set TestIF = Sh
Sh.Range("A1:E5").Value = TestIF.GetTestArray ←例えば2次元配列を返す
とか書ければスッキリするんですけど、そもそも確実には動かないので使い物になりません・・・
>>923 セキュリティの設定を変更しないとダメだが、一応これなら2007ではうまくいった
2003は持ってるけどインスコめんどいので試してないからやってみれ
-ThisWorkbook-
Private Sub Workbook_Open()
On Error GoTo SECURITY_ERROR
Dim p As Variant
For Each p In ThisWorkbook.VBProject.VBComponents
Debug.Print p.Properties("Name").Name
Next p
Exit Sub
SECURITY_ERROR:
'
http://support.microsoft.com/kb/282033/ja Call MsgBox("セキュリティ設定によりマクロからVBAプロジェクトへのアクセスが禁止されています。", vbCritical, "セキュリティ エラー")
End Sub
>>923 「動かなかったり」って時は、VBAProjectがコンパイルされてない時とイコールだったりしない?
うーん、何かそのやり方違和感があるなぁ。 class Worksheet implements IFooじゃないところが。つまり、implementsを書かないworksheetが存在してもOKなところ。 じゃぁ、どうやればいいかって聞かれると、即答できない・・・
iの型は何にすればいいんですか?
929 :
920 :2007/12/10(月) 21:33:47
>>924 動きました! ありがとうございます!
923みたいに、配列を返してセルをまとめて埋めちゃうような処理でもバッチリ動きました。
処理を目にしても、なおピンと来ませんが、前もって1度アクセスしとくって感じですかね。
凄いなー・・・ そんなの絶対に分からないです。俺ももっと精進します・・・
応用を考えて、色々試して見ます。本当にありがとうございました。
>>925 コンパイルが通らないときは動きません。 通っても一旦終了するとダメだったりしてました・・・
>>926 そうなんですよね、”何となくダメっぽい” んですけど、どうすればいいかサッパリな事が多くて。
相撲の世界では、雲龍型もしくは不知火型のどちらかだよね。
今度からiは整数型にします><
>>929 アフォか
実体を取得してないのにインプリメントしただけで参照が通るわけネーダロ
まあ、モジュール行ったり来たりの実用性に乏しいところを見ると、単なる実験だろうけど
以下のコードをSheet1の方に記述してから、このプロパティを呼び出してみ
Public Property Get MyEntity() As ClassIF
Set MyEntity = Me
End Property
それにしてもiはインデックスとか1文字変数野郎にはキチガイが多いな(~ε~;)
iは整数型なんですってば><
932が見えない またキチガイが来てるのかw
>>926 ベストなやり方とは言えないが、これで現状の処理に合わせたまま対応できるな
'参照設定 TypeLib Infomation
Private Sub Workbook_NewSheet(ByVal Sh As Object)
Dim m As CodeModule
Dim c As ClassIF
Dim t As TLIApplication
Dim v As Variant
Set t = New TLIApplication
Set c = New ClassIF
Set m = ThisWorkbook.VBProject.VBComponents(Sh.Name).CodeModule
Call m.AddFromString("Implements ClassIF")
For Each v In t.InterfaceInfoFromObject(c).Members
Call m.CreateEventProc(v.Name, "ClassIF")
Next v
End Sub
936 :
920 :2007/12/10(月) 23:08:18
>>932 機能を増やした時の保守性のため、ClassIF を抽象クラス的に使おうとしてます。
なので、できれば Sheet1 に外部からアクセス(Public定義)させたくないのです。
従って、ClassIFを返す意味がないのです。
それから、多分それだと動きません。(そもそも実行時に MyEntityを取得できない)
意図を読み違えていたらすいません・・・。
アクセルロッドのコンテストを学校の課題でしており、 Sub Dilemma_of_Prisoners() Dim TE1 As Boolean, TE2 As Boolean, preTE1 As Boolean, preTE2 As Boolean Dim I As Integer, N As Integer point1 = 0 point2 = 0 N = 5 ' 繰り返し回数 For I = 1 To N TE1 = Player1(I, preTE2) TE2 = Player2(I, preTE1) preTE1 = TE1 preTE2 = TE2 If TE1 Then If TE2 Then point1 = point1 + 3 point2 = point2 + 3
Else point1 = point1 + 0 point2 = point2 + 5 End If Else If TE2 Then point1 = point1 + 5 point2 = point2 + 0 Else point1 = point1 + 1 point2 = point2 + 1 End If End If Next I MsgBox "プレイヤー1=" & point1 & vbCrLf & "プレイヤー2=" & point2 Range("A1") = "プレイヤー1=": Range("C1") = point1 Range("A2") = "プレイヤー2=": Range("C2") = point2 End Sub
↑判定ルーチン '人間がプレイする場合のルーチン Private Function Player2(kaisu As Integer, TE As Boolean) As Boolean ' プレイヤーが人間の場合 If kaisu = 1 Then Reply = MsgBox("協調しますか?", vbYesNo, "(" & kaisu & ")回目") Else If TE Then aite = "「協調」" Else aite = "「裏切り」" End If Reply = MsgBox("前回、相手は" & aite & "でした。" & vbCrLf & _ "協調しますか?", vbYesNo, "(" & kaisu & ")回目") End If If Reply = vbYes Then Player2 = True Else Player2 = False End If End Function
↑人間が入力する際のルーチン コンピューター側の行動を書きに沿って作っているのですが、 1.しっぺ返し戦略 2.「裏切り」戦略 3.罰戦略 4.寛容戦略 5.でたらめ戦略 6.独自の戦略
裏切り Private Function Player1(kaisu As Integer, TE As Boolean) As Boolean If kaisu = 1 Then Player1 = False End If End Function 寛容 Private Function Player1(kaisu As Integer, TE As Boolean) As Boolean If kaisu = 1 Then Player1 = else End If End Function
しかできず、他の方法に関して模索しております。 お知恵を頂けないでしょうか? お願いいたします。
★4 とりあえず、Excelのインスタンスを作らずにVB6で出来ることは全てスレ違いだと思ってください。
>>920 moduleに、
Public Function GetTestString(ByRef w As Worksheet) as Hoge
Select Case w.Name
・・・
End Select
End Function
とかやったほうが、何の問題もなく、すっきりしてる気がする。
>>944 これはひどいww
これじゃプライベートなデータを全部公開しないと処理ができないじゃないかw
え、まさかシートのコードモジュールをメインでプログラミングしてたりするのか?
あー、違和感の原因がやっとわかった。 俺、アドインベースが基本だから、シートにコード書くこと今までほとんどなかった。
カプセル化が必要な場合は、俺ならメンバにワークシートを持つクラスを定義する。
949 :
デフォルトの名無しさん :2007/12/11(火) 16:36:37
(コントロールツールボックスでは無い方の) コントロールのオブジェクト名と値をVBAで 参照することはできますか?
もっと具体的に
>>946 > え、まさかシートのコードモジュールをメインでプログラミングしてたりするのか?
これをやると何か得するのですか?
得しないよ? つか、何で俺にそれ聞くの?
953 :
949 :2007/12/11(火) 17:45:13
>>950 フォームコントロールのオプションボタン1と2を
ブックを開いたとき、クリア(押されてない状態)に
したいのですが、コントロール名がないためやり方がわからなくて・・
後出しですみません。
うーむ、UserForm1.OptionButton1.Value=0とは違うのか?
フォームツールボックスのオプションボタンをシートに配置して使ってます。 こいつのプロパティを開いてもコントロールの名前がないのです・・
>>953 Worksheets(1).Shapes(1) とかでアクセスできる
名前はないからリンクしているセルの番地で特定するとか
つけてるラベル名でやるとか、最悪インデックスを直値でやる
以下はセルA1とリンクしているコントロールを見つけだす例
For Each v In Worksheets(1).Shapes
If v.ControlFormat.LinkedCell = "$A$1" Then
End If
Next v
シートにコードを書くのってフォームを呼び出すときぐらいっしょ
958 :
920 :2007/12/11(火) 21:08:22
みなさん、昨日はありがとうございました。 920のその後ですが、ゴリゴリ処理を追加して起動すると、再度エラーが起きるようになりました。 For Each p In ThisWorkbook.VBProject.VBComponents Debug.Print p.Properties("Name").Name Next p ここで、「'Properties'メソッドは失敗しました: '_VBComponent'オブジェクト」のエラーとなります。 しかも、確認のためステップ実行するとエラーは起きません。意味も分からず、試行錯誤の末、 For Each p In Me.VBProject.VBE.CodePanes s = p.CodeModule.Name Next p のように修正したところ、今のところ何故か動いてます。 理屈はまだまだサッパリです・・・。 一応、ご報告まで。
他の人も言ってるけど、そのやり方止めたほうが良いと思うよ。 まぁ、将来にわたって自分ひとりしか使わないし、シートも追加しないしってことなら止めないが・・・。
>>955 或る程度、分かってる人みたいなので手抜き
Set objSheet = Excel.Worksheets("ターゲットシート名とか")
For Each objShape In objSheet.Shapes
If objShape.Type = msoFormControl Then
If objShape.FormControlType = xlOptionButton Then
objShape.ControlFormat.Value = xlOff
End If
End If
Next
msoFormControlは結構、有名だと思ったけどそうでもないのね
デタラメこいてクサレコードを教えるヤツも出るぐらいだし(~ε~;)
あ、あぼんされてる人だ
963 :
デフォルトの名無しさん :2007/12/11(火) 23:41:06
r AS Range n AS Integer (rにはセル範囲が与えられているとして) n=r.Areas.Columns(1).Count←行数を取得したい どうすれば行数を取得できるでしょうか?
964 :
920 :2007/12/11(火) 23:42:45
>>959 ありがとうございます。おかげさまで、考え方が良くないという認識は持てました。
ただ、どうも"何故"という興味が消えなくてw 不具合か、使い方か、追求してみたいです。
ご忠告どおり、個人レベルは超えないようにして、
948さんの考え方等も色々試してみようと思います。 みなさん、ありがとうございました。
>>963 Set r = Range("a2:d11")
n = r.Rows.Count
Range("a1") = n
966 :
デフォルトの名無しさん :2007/12/12(水) 00:20:21
>>965 ありがとうございました。
d AS Variant
n=300←(データ数。可変する)
Redim d(n,2)
(省略)←dにグラフの値を代入する
Chart.add
Activechart.setsource
d←配列データをもとにグラフを作成するにはどうすればよいのでしょうか?
oshietekun shirabenai kara oshietekun
>>967 いや、一ヵ月前から調べたが解決できなかったのがたまたまこの2つだったのです。
969 :
デフォルトの名無しさん :2007/12/12(水) 10:47:08
if thenで改行するのと、そのまま書き続けるのって ひょっとして全然違う?
>>960 とんでもないクサレコードだなおいw
それじゃ手あたり次第に同種のコントロールを設定しちまうだろw
973 :
デフォルトの名無しさん :2007/12/12(水) 11:57:42
>>972 ありがとうございます!
もうひとつ、ついでによろしいでしょうか?
変数を使ったセルの選択で、結合されている場合の
やりかたが分かりません。
Range("B & i : B & i+1").Select: triggerMsg = Selection.Value
もしくは
Range(""B" & i : "B" & i+1"").Select: triggerMsg = Selection.Value
これだと、ダメなんですよね。
974 :
973 :2007/12/12(水) 12:09:48
ひょっとして、これであってます? dim range1 as range Set range1 = Range("B" & i).MergeArea
>>973 くくってる範囲が違う
Range("B" & i & ":B" & i+1")
976 :
デフォルトの名無しさん :2007/12/12(水) 13:00:04
>>966 > d AS Variant
> n=300←(データ数。可変する)
> Redim d(n,2)
> (省略)←dにグラフの値を代入する
>
> Chart.add
> Activechart.setsource
> d←配列データをもとにグラフを作成するにはどうすればよいのでしょうか?
配列データからグラフ作成、以外と難しいね
977 :
デフォルトの名無しさん :2007/12/12(水) 13:03:16
msgboxのvbokcancelで、キャンセルを選んだ場合に返される 値って、「vbcancel」なのか「false」なのか、どっちですか?
978 :
973=977orz :2007/12/12(水) 13:06:09
>>975 ありがとうございます!
こう?
Range("B" & i & ":B" & i + 1).Select
ExcelのChartではできません。あきらめましょう。
981 :
973 :2007/12/12(水) 13:18:44
Sub yoyoyo() Range("A" & 1 & ":A" & 2).Select: hoge = Selection.Value MsgBox hoge End Sub 型が違うって出てしまいます。 結合されたセルの値を取り出すには、 特別な作業が必要なんですかね。
>>981 いつまでその調子で質問し続けるつもりだ?
984 :
973 :2007/12/12(水) 13:50:13
すんません
>>981 一旦選択状態にする意味が分かんない。それすら分かってないレベルなら
>>982 まとめて取得したいって意味なら、2次元配列で受け取る方法を考える。
つか、クイックウォッチを見ながらやってみ?
>>984 もし本を読んだ上で質問していると思うけど、複数冊参考になる本は用意しておくべきだよ。
その本ごとに強調する部分は違うからね。
とりあえず本屋へGo!
>もし本を読んだ上で質問していると思うけど 日本語でOK
988 :
973 :2007/12/12(水) 15:55:32
ありがとうございます 色々やってたら出来ましたぁ
>>981 > Sub yoyoyo()
hoge AS Range
Set hoge = Range("A1:A2").Value
> MsgBox hoge
> End Sub
>>989 >
>>981 修正。
Sub yoyoyo()
Dim hoge AS variant
Redim hoge(1,2)→行と列は忘れた。
Set hoge = Range("A1:A2").Value
MsgBox hoge
End Sub
>>979 > ExcelのChartではできません。あきらめましょう。
どおりで一ヵ月ネットで探してもでてこないわけですね・・
ありがとうございました
あきらめてシートに転記してグラフ化するがよろし
うわ、次スレの季節。 はよせんと落ちてしまう〜、誰かヨロ
994 :
981 :2007/12/12(水) 16:56:31
>>981 hogeは2次元配列になっている
Sub yoyoyo()
Range("A" & 1 & ":A" & 2).Select: hoge = Selection.Value
MsgBox hoge (1,1) & vbLf & hoge(2,1)
End Sub
としないと動かない。
だがちょっと待って欲しい。変数の宣言をした方が良いんではないだろうか。
Sub yoyoyo()
Dim hoge As Variant
hoge = Range("A1:A2").Value
MsgBox hoge (1,1) & vbLf & hoge(2,1)
End Sub
とすればSelectしなくても良いのではないかという声が聞こえなくもない。
A1とA2は結合されてるのか。 だったら Sub yoyoyo() Dim hoge As Variant hoge = Range("A1").Value MsgBox hoge (1,1) End Sub
ひとりごとはチラ裏な
すまん間違いな Sub yoyoyo() Dim hoge As Variant hoge = Range("A1").Value MsgBox hoge End Sub MsgBox Range("A1").Value の1行でもいいぞ。
1000 :
1000get :2007/12/12(水) 17:45:26
>>999 結合されていると、なぜかselect後の値取得が
使えないんです。
range("A1").select:hoge=selection.value
はエラーになる。
1001 :
1001 :
Over 1000 Thread このスレッドは1000を超えました。 もう書けないので、新しいスレッドを立ててくださいです。。。