Excel VBA 質問スレ P ..
[2ch|▼Menu]
405:デフォルトの名無しさん
10/02/25 12:14:46
すみません、もうひとつ聞きたいことがあるんですが、
星の表示で1〜n個の*を順番に表示させるプログラムをつくったんですが、
Sub 星の昇順表示()
'1 〜 n個の”* ”を順番に表示
Dim i As Integer, n As Integer
n = 10
Do
Debug.Print Format(i, "00") & String(i, "*")
i = i + 1
Loop While i < 11
End Sub
これをn〜1個の*を順番に表示させるためにはDo〜Loopを使ってどのように変えればいいのでしょうか?
教えていただけないでしょうか。

406:デフォルトの名無しさん
10/02/25 12:45:59
>>405
初期値
加算値
終了条件

宿題け?

407:デフォルトの名無しさん
10/02/25 17:48:25
Dim y As Integer
Dim x As Integer
Dim objTableItem As Object

'.body ‚loop body data
For Each objTAG In objIE.document.body.all
'search for table tag
If objTAG.tagName = "TABLE" Then
'add new sheet
Sheets.Add
y = 0 'row
'loop item in table
For Each objTableItem In objTAG.all
If objTableItem.tagName = "TR" Then
y = y + 1 'row +1
x = 1 'columm=1
End If
If objTableItem.tagName = "TD" Then
'set text data
Cells(y, x) = objTableItem.innerText
x = x + 1 'next columm
End If
Next
End If
Next

このままだと、Excelを使ったIE操作に関する質問です。
website上のテーブルをコピーして、エクセルにペーストしたいのですが、このままではテキストにリンクが貼られていても、
テキストしかコピーできません。
例えば、<a href ="http.....">VBA</a>の場合、テキストのみがペーストされますが、エクセル上でVBAをクリックすると、URLにジャンプできるようにしたいのですが、何かいいアイディアはございますか?

408:デフォルトの名無しさん
10/02/25 18:58:19
>>406
回答ありがとうございます。
すみません、具体的にはどこをどう変えればいいのでしょうか。
本当に初心者なので、どこをどういうふうに変えたら*の数が下がるようになるのかわからないんです。

409:デフォルトの名無しさん
10/02/25 22:22:30
>>407
If objTableItem.All.tags("A").Length > 0 Then
Debug.Print objTableItem.All.tags("A")(0).href
End If

http.....
が取得できると思うけど

410:デフォルトの名無しさん
10/02/25 23:46:43
>405

★5 レベルはどうあれ、ここはプログラマ用の板スレです。プログラマとは、自分でプログラムを組み
   コードを書く人の事なので、自分でやるきは全く無く、丸投げしようって人はお断りです。
   ヒントを貰えばあとは自力でなんとかしますって人のみどうぞ。

411:デフォルトの名無しさん
10/02/26 00:30:18
ユーザーフォーム上のテキストボックスに前のデータを表示させたまま下に出力し続けることは可能でしょうか?


412:デフォルトの名無しさん
10/02/26 00:58:33
>410
仰るとおりです。本当に申し訳ありません。
ただ、時間がなくプログラムもどう変えればいいか全然わからず、丸投げしてしまいました。
厚かましいお願いではありますが、初心者でもわかる範囲でヒントをもらえないでしょうか。
見よう見まねで上のプログラムは組めたんですが、反対に星の数を少なくしていくやり方がどうしてもわかりません。
どうかよろしくお願いします。

413:デフォルトの名無しさん
10/02/26 01:52:16
>>408
なんかの宿題だろうけど
見よう見まねだとしても
>>405の コードでなぜ星の数が多くなっていくのか
それを理解するのが先だと思う

じゃあ逆に質問
1〜5個の"*"を順番に表示にするには?どう修正する?
実行結果は下ね

01*
02**
03***
04****
05*****

ちなみに下だと失格だよ
00
01*
02**
03***
04****
05*****

414:デフォルトの名無しさん
10/02/26 02:06:08
>>412
i = 10
i = i - 1
i > 0

415:デフォルトの名無しさん
10/02/26 02:41:02
Dim i As Integer, j As Integer, n As Integer, s As String
n = 10
For i = 1 To n Step 1
s = Format(i, "00")
For j = 1 To i Step 1
s = s & "*"
Next j
Debug.Print s
Next i
End Sub

そういえば、iとかjとか一文字の変数名はよくないって話はどうなってんの

416:デフォルトの名無しさん
10/02/26 03:02:49
>414
できました!助かりました!本当にありがとうございます。
>413
i = 1 という条件を付け加えればよかったんですね!
一人じゃ何もわからず、途方にくれていました。本当に助かりました。
ありがとうございました。


417:デフォルトの名無しさん
10/02/26 08:18:56
>>415
変数名1文字なんてどうでもいい
それよりループ回してs=s&"*"なんて恥ずかしいからやめろ
>>405さえString関数使ってるだろ?

418:415
10/02/26 09:54:18
なんで?

01*
02*+
03*+*
04*+*+
05*+*+*

こういうのやる時必要でしょ?

419:デフォルトの名無しさん
10/02/26 11:01:47
>418

ヲイヲイ・・・

420:デフォルトの名無しさん
10/02/26 11:23:13
For文で変数にiとjを使うのは昔からの慣習なので問題ない

421:デフォルトの名無しさん
10/02/26 15:39:29
時間がないと言ってるのに>>413はちょっとかわいそうだとオモタ

422:デフォルトの名無しさん
10/02/26 19:40:12
名簿から名前(アルファベット)を拾って
頭文字別の一覧表シートを作成しようとしています。
ソート後に頭文字を
if str[i] == str[i+1]
hoge列に代入
elseif str[i] != str[i+1]
hoge = hoge+1
hoge列に代入
という方法でやろうと思ってるんですが
(if a 〜 if z では長くて面倒ですし・・)
他に方法というかVBA側で用意されてるものってあったりしますか?
リスト構造体的なものがあってそこに文字列ぶちこんで
検索文字抽出→GetNextで抽出文字列を順々に引っ張り出せたりとか・・
そういったものがあったりしないかなぁと思い質問させていただきました。


423:422
10/02/26 19:43:33
== → =
!= → <>
に訂正します。
比較演算子がC++になってしまいました・・

424:デフォルトの名無しさん
10/02/26 21:19:44
>>422
(if a 〜 if z では長くて面倒ですし・・)

の部分が何が言いたいのかよくわからん。
例示されたプログラムのどこにも出てきてないのに、いったい何がやりたいんだ。

425:デフォルトの名無しさん
10/02/26 21:36:06
>>422

1Byte文字かつアルファベットのばあい。

文字列の先頭1文字の文字コード(アスキーコード)取得して適当に計算して
Cell位置に変換してそこにぶち込む。をLoopすれば?
カラム方向のカウンタも配列にして。

426:422
10/02/26 22:06:04
>>424
if str[i] like "Aa" 〜 if str[i] like "Zz"
ということでした。わかりづらくて申し訳ありませんでした

>>425
やはりLoopで回すのが手っ取り早そうですね。
ありがとうございます。

427:デフォルトの名無しさん
10/02/26 22:22:51
>>417
別にええやんと思う人間が実はここにもいる。
性能的な違いはある?

428:デフォルトの名無しさん
10/02/26 23:57:22
>417
>それよりループ回してs=s&"*"なんて恥ずかしいからやめろ

途中の結果も必要なんだから別に恥ずかしいとは思わんが・・・

429:427
10/02/27 01:21:43
あ、文字列を作るためだけにループ使うなと言いたいのか。
でもString関数なんて今まで知らなかったよ。

ところで文字を連続させる関数て何に使うんだろうか。

430:デフォルトの名無しさん
10/02/27 08:35:11
>>429
文字を連続させるために使う。

431:デフォルトの名無しさん
10/02/27 08:55:01
使いたい人が使いたいときに使う。

例えば*を100個書きたい場合(101個だとダメ99個でもアウト〜)に
String()を使えば間違わないで書けるとかじゃろ?

432:デフォルトの名無しさん
10/02/27 09:38:38
worksheetfunction に rept ってなかったっけ?

433:デフォルトの名無しさん
10/02/27 13:13:17
だめだ、同じ文字を10個ならべる目的が思いつかない。
固定だったら"**********"とか書くし需要少なそうだ。

まあ、あるものは使った方がいいのは確かだと思う。
String関数の中でループ処理が組んであるんだろう。

434:デフォルトの名無しさん
10/02/27 13:42:12
バリアント型 (内部処理形式 String の Variant) の値を返します。
指定した文字コード (ASCII またはシフト JIS コード) の示す文字、または文字列の先頭文字を、
指定した文字数だけ並べた文字列を返す文字列処理関数です。

Dim MyString

MyString = String(5, "*") ' "*****" を返します。
MyString = String(5, 42) ' "*****" を返します。
MyString = String(10, "ABC") ' "AAAAAAAAAA" を返します。

435:デフォルトの名無しさん
10/02/27 13:49:08
ForとString()じゃパフォーマンスが段違いに違う。
String(999999999,"*")は一瞬で処理されるのに対し、ForはExcel自体がフリーズする。

436:デフォルトの名無しさん
10/02/27 13:49:20
>>433
目的ですか、うちでよく使うのは
その1、ダミーデーター作成(スペースでいい場合はspace()を使うけど)
    1.1、固定でも200個とか数えるのやだし
    1.2、固定長データを扱うときにあまった領域の埋め草を作るのに使う
その2、CUIで棒グラフ

あとは、なんだろうね、なにかあったような気がするが思い出せない


437:デフォルトの名無しさん
10/02/27 13:50:37
たとえば

あるLoop処理でc言語のTableを作るとかの場合に、
タブを何個挿入するのかをブレイスの深さで変えたい場合、
ブレイスの深さをカウンタにしておけば少し便利かも。
タブじゃなくてスペース4個とかでも同じ。

String(i, Chr(9)) & StringBuff & vbLf

438:デフォルトの名無しさん
10/02/27 13:50:43
ごめん9が1個多かった

439:デフォルトの名無しさん
10/02/27 14:44:21
なるほど、固定長データを埋めるときという例はすごくよく判ったし
パフォーマンスが全然違うんだね。ありがとう。

生の固定長データを自分で作ったことが多分ないから気づかなかったよ。

440:デフォルトの名無しさん
10/02/27 16:02:28
だんだん文字列を大きくしていくのはメモリ確保に時間がかかるからやらないのが常識。
サイズが小さいうちは平気だけどね。

441:デフォルトの名無しさん
10/02/27 17:45:33
それは何nsの話なのか

442:デフォルトの名無しさん
10/02/27 18:39:18
小さいうちは数ナノ秒でも大きくなると幾何級数的に時間がかかるよな。


443:デフォルトの名無しさん
10/02/27 20:11:25
excel2003を使用しています。
ファイルを外部から取り込む際に、ダイアログを使用していますが、
この取り込むときのフィルターのかけ方で、特定の文字列を含むファイルのみ表示することは可能でしょうか?



Filter = "エクセルファイル(*.xls)" & Chr(0) & "*.xls" & Chr(0)


現状はこの様になっており、拡張性がエクセルファイルのものだけを表示するようになっています。
これに特定の文字列を持ったファイル名を表示するという条件を追加できませんか?エクセルファイルで、名前が091201を含むなど




444:デフォルトの名無しさん
10/02/27 20:13:24
>>441
性能問題起こしそう

445:デフォルトの名無しさん
10/02/27 20:16:35
"09*.xls"

446:デフォルトの名無しさん
10/02/27 20:53:18
まぁ、スピードが要求されるならC++でDLL書いてVBAから呼べって話になるんですがね

447:デフォルトの名無しさん
10/02/27 22:02:08
そういう問題じゃねーのまだ分ってねーの
計算量のオーダが2乗ってことだよ

448:デフォルトの名無しさん
10/02/27 22:04:49
ほら
1+2+3+...+n=n(n+1)/2=n**2+1/2*n

449:デフォルトの名無しさん
10/02/27 22:28:51
流れを無視してすみません
VBA初心者ですが質問させてください

Userformでの話なのですが
ボタンが押された際に
TextBoxにセルの値を代入し表示
2秒間隔をあけ、その後フォームを閉じる

という処理を行いたいのですがTextBoxに表示される前にフォームが閉じられてしまいます。
フォームが閉じられる前にTextBoxにテキストを表示させるにはどのような方法をとればいいのでしょうか?

サンプルコードは以下のとおりです。

Private sub CommandButton1_Click()

TextBox1.text = sheets("sheet1").range("A1").value

call delay(2) '2秒ディレイするという命令

Unload Me

endsub

分かりづらいコードで申し訳ないですがご指導のほどお願いいたします。

450:デフォルトの名無しさん
10/02/27 22:40:23
>>445
ありがとうございます!!

451:デフォルトの名無しさん
10/02/27 22:43:48
どうしてもその自作関数つかうなら
delayのほうに
閉じる動作書けばいんじゃね

452:デフォルトの名無しさん
10/02/27 23:09:19
>>447
.NET Framework使えよって話だ

453:デフォルトの名無しさん
10/02/28 00:17:06
>>449 ontime

454:デフォルトの名無しさん
10/02/28 00:40:48
VBAで指定されたURLに日本語をくっつけてWebを開く事は出来ますが
そうではなくて
開いたWebページのあるテキストボックスに選択されたセルにある文字列を入力して
ボタンを押下する方法とかはあるのでしょうか?

もしあればご教授お願いします

455:デフォルトの名無しさん
10/02/28 01:10:19
>>454
Sendkeys

456:デフォルトの名無しさん
10/02/28 11:21:20
>>449
DoEvents を使ってみるといいかも

TextBox1.text = sheets("sheet1").range("A1").value
DoEvents
call delay(2)
Unload Me

457:デフォルトの名無しさん
10/03/01 01:46:21
テキストファイルA.txtの内容をstrAとし、
テキストファイルB.txtの内容をstrBとし、2つを合体させて
クリップボードにコピーしようとしています。

strA も strB も、それぞれ読み取れてはいるのですが、
strA & strB とすると前者の方しかコピーされません。
逆にしても同じです。

&でつなぐことはできないのでしょうか?

458:デフォルトの名無しさん
10/03/01 02:42:09
>>457
よくわかりませんが、先に

strAB = strA & strB

したり、そこで文字列結合関数を使ってみては?

459:デフォルトの名無しさん
10/03/01 19:14:57
nul文字混入

460:デフォルトの名無しさん
10/03/02 22:00:35
Worksheets("225構成銘柄(業種別分類)").Range(Cells(2, 1), Cells(2, 2)) = Worksheets("水産").Cells(3, 3)

これでアプリケーション定義またはオブジェクト定義のエラーです。が出るのは何でだ?
もしかしてシートまたいでのコピーっていちいちactiveにせないかんの?
簡略表記できないの?

461:デフォルトの名無しさん
10/03/02 22:50:10
>>460
1.
Worksheets("225構成銘柄(業種別分類)").Activate
Range(Cells(2, 1), Cells(2, 2)).value = Worksheets("水産").Cells(3, 3).value

2.
With Worksheets("225構成銘柄(業種別分類)")
.Range(.Cells(2, 1), .Cells(2, 2)).value = Worksheets("水産").Cells(3, 3).value
End With

3.
Worksheets("225構成銘柄(業種別分類)").Cells(2, 1).Resize(1, 2).value = Worksheets("水産").Cells(3, 3).value

お好きなのをどうぞ

462:デフォルトの名無しさん
10/03/02 23:22:41
なんか納得いかないけどありがとう御座います。
とくに2なんかwithで囲っただけでなんで上手く行くんだ?

463:デフォルトの名無しさん
10/03/02 23:52:33
>>462
RangeやCellsはシートを指定しないとアクティブシートを対象とする。
そのため460の書き方では、CellsのシートとRangeのシートが一致していない。
461の.Cellsはドッドが付いているため.Rangeと同シートを対象としているので動く。

と正しくないかもしれないけど勝手解釈な説明をしてみた。

464:デフォルトの名無しさん
10/03/03 08:47:09
>>457
(strA & strB)
としてはどうか

465:デフォルトの名無しさん
10/03/03 16:46:26
>>463
ふんわりと勉強になった。
知らん事だらけで困惑する。

466:デフォルトの名無しさん
10/03/03 20:11:36
簡単に言うと、
Cells(2, 1), Cells(2, 2)
ってのが、どこのシートのセルか指定されてないってことね。

467:デフォルトの名無しさん
10/03/03 21:25:06
現在VBAでエラーが出た場合

On Error GoTo ErrorHandler
ErrorHandler:
MsgBox "エラーが発生しましたので終了します"

のように強制的に終了させていますが
これだとどこでエラーが起こったのかわかりません。
しかしこれをはずすとVBAの画面が出てきてしまうのでそれは何としても避けたいのですが

いわゆる実際の開発現場での作業などで作成される場合、
一般的にデバッグってどうやってされているのでしょうか?

たとえば通過ログを各地にはりつけてこのログが通って、このログが通っていないので
その間で落ちたと言うやり方が思いつくのですが、
あるいはこの部分で落ちたとかがわかるコードなどあるのでしょうか?


468:デフォルトの名無しさん
10/03/03 21:32:39
>>467
Debug.Assert(条件文)

469:デフォルトの名無しさん
10/03/03 21:40:30
Err.Description じゃなかったっけ?
それみてエラー箇所が特定出来ないなら関数が大きすぎるんじゃないか?

470:デフォルトの名無しさん
10/03/04 00:22:40
>>467
とりあえずErrオブジェクトでぐぐれ
エラーの発生した場所を正確に知るにはErl関数を使うという手もあるが
使い方がかなり面倒なのでおすすめはしない

471:デフォルトの名無しさん
10/03/04 00:28:40
ちがう
Err.LineNumber

472:デフォルトの名無しさん
10/03/04 01:06:17
>>467
VBEのメニューバーにそのものずばり「デバッグ」てのがあるでしょ
いちいちソースを書き換えなくても、どこまで実行したら一時停止とかできるんだよ

473:デフォルトの名無しさん
10/03/04 16:44:12
>>471
ErrオブジェクトにLineNumberなんてプロパティある?

474:デフォルトの名無しさん
10/03/04 20:12:54
Excelにプルダウンを入れていて、いくつか選択肢を入れているのですが
Excelを最初開いた時には空白で
別のシートを選択して、またこのシートに戻ってきた時に表示されます
これの原因ってわかりますでしょうか?
初期化がうまくいっていない気がしますが
どうしても理由が分かりません

ちなみにコードとしては
VBAプロジェクトの同じシートの中に下記の記述を入れています
Private Sub Worksheet_Activate()
With Me.Director_Combo
.Clear
.AddItem ""
.AddItem "あああ"
.AddItem "いいい"
.AddItem "ううう"
.ListIndex = 0
End With
End Sub


475:デフォルトの名無しさん
10/03/04 20:22:51
>>474
ThisWorkbookのWorkbook_Openイベントに記述する
シートの指定を忘れずに


476:デフォルトの名無しさん
10/03/04 21:48:31
ある文字列中に.が何個あるか出力したいんですけど、どうすればいいですか?
例えば"1.25.30.2"ならば3を出力したいです。

477:デフォルトの名無しさん
10/03/04 21:59:28
>>476
単純に思いついたコードなんで間違ってたらすまん

Dim wkArr() As String
wkArr = Split("1.25.30..", ".")
MsgBox UBound(wkArr)

478:デフォルトの名無しさん
10/03/04 22:11:36
あんまりスマートじゃないな
s = "12.34.56.."
Debug.Print Len(s) - Len(Replace(s, ".", ""))

479:デフォルトの名無しさん
10/03/04 22:30:41
>>478
なるほど。LenとReplaceを組み合わせるんですね。
どうもありがとうございます。

480:デフォルトの名無しさん
10/03/07 00:01:38
Sheets(intS).Activate
ActiveSheet.Range("C3:C100").AutoFilter Field:=1, Criteria1:=ANAME
Range("C100").Select
Selection.End(xlUp).Select
If Selection.Value <> "あああ" Then
Range(Selection.Offset(0, -2), "E4").Copy

Sheets(intB).Activate
Range("C100").Select
Selection.End(xlUp).Select
If Selection.Value <> "" Then
ActiveCell.Offset(1, 0).Range("A1").Select
End If
ActiveSheet.Paste  ←
End If
Selection.AutoFilter

矢印の部分でWorkSheet クラスの Paste メソッドが失敗しましたのエラーになってしまいます。

* Microsoft Visual Basic for Applications (VBA) マクロで、Excel 2003 ブックの 1 行全体のコピーと貼り付けを実行している。
* Microsoft VBA マクロで、Excel 2003 ブックの 2,516 以上の行の範囲のコピーと貼り付けを実行している。

のどちらにも当てはまっていないと思うのですが、なぜでしょう。

481:デフォルトの名無しさん
10/03/07 00:03:56
ごめんなさい書き忘れました。
Windows7 Office2007 です

482:デフォルトの名無しさん
10/03/07 08:20:54
やってはいけないの見本

483:デフォルトの名無しさん
10/03/07 09:46:48
>>480
コピー元かコピー先のどちらかでセルが結合されてない?

484:480
10/03/07 17:31:48
セルの結合はないです。
PasteSpecialでも同様のエラーが出ます

485:デフォルトの名無しさん
10/03/07 19:38:09
VBAを利用して

Webページにある複数のテキストボックスに
A1セルに書かれている内容をWeb上のAというテキストボックスに入力
A2セルに書かれている内容をWeb上のBというテキストボックスに入力
するような物を作りたいのですが
やり方とかあるのでしょうか?

あれば教えてください

486:デフォルトの名無しさん
10/03/07 20:22:08
>>485
IEオブジェクト.Document.フォーム名.テキストボックス名.value = 設定したい内容

フォーム名やコントロール名が無い場合
DocumentオブジェクトのFormsコレクションやItemコレクションを使う

IEオブジェクト.Document.Forms(n).Item(n).Value = 設定したい内容

487:デフォルトの名無しさん
10/03/07 21:56:28
A〜E列を下記。A,Dを検索キーとしてBをEに移します。
test()では1が拾えず10を拾ってしまいます。(XP, Excel2000)
どう修正すればよいでしょう。
A B C D E
-- -- -- -- --
1 あ __ 1
2 い __ 2
3 う __ 3
9 け __ 9
10 こ __ 10
11 さ __ 11
14 せ __ 14
15 そ __ 1

Sub test()
Set myRngA = Range("A1:A15")
Set myRngD = Range("D1").CurrentRegion
For i = 1 To myRngD.Rows.Count
myKey = myRngD.Cells(i)
Set myCel = myRngA.Find(what:=myKey)
If Not myCel Is Nothing Then
myRngD.Cells(i, 1).Offset(0, 1) = myCel.Offset(0, 1)
End If
Next i
End Sub

488:デフォルトの名無しさん
10/03/07 22:49:54
>>487
Set myCel = myRngA.Find(what:=mykey, LookAt:=xlWhole)

489:デフォルトの名無しさん
10/03/07 22:54:31
大量の日付+株価の四本値データ(1まとまりで5列使用)があるのですが、開始日も終了日も全てバラバラ(最長の奴で8192日データ。この8192日の中に全ての期間入ってる)
綺麗に日付の行をそろえて昇順でソートしたいのですが、VBAで上手いことやるアイデアを下さい。

490:デフォルトの名無しさん
10/03/07 23:29:40
>>489
ソートするって、四本値データが日付順にならんでないというのが不思議だが
同じ日付を同じ行に持ってきたいということかな?
もしそうなら
ビンソートでデータをビンに詰め終わったところで
空きビンに対応する日付データーを入れてやればいいんでないかな


491:487
10/03/07 23:38:31
>488

ありがとう。たすかりました。

LookAt:=xlWholeがないと、一行目が無視されるわけですね?

492:デフォルトの名無しさん
10/03/08 01:24:39
>>491
全然違う。
LookAt=xlWholeは完全一致。
これを書かないと初期状態ではLookAt:=xlPartの部分一致になる。
開始セルのAfter:=***を書かないと範囲の先頭の次から検索するので
部分一致で10がヒットすることになる。


493:489
10/03/08 01:37:33
ビンソートという用語初めて知った。情報有難う。

ソート自体は簡単なんだけど、データのスタート位置設定するの難しいわ。
日付が素直に+1日づつなら多少は簡単なんだけど、休場日とかのせいで日付が飛び飛びなのがうっとうしい・・・

後学の為にVBAで処理したいけど、もう手作業でやるか?

494:デフォルトの名無しさん
10/03/08 01:57:54
SQL使えよ

495:デフォルトの名無しさん
10/03/08 12:36:05
SQLもビンソートも不明だったので。

@→一番長い日数入ってる列探して基準にする
A→各銘柄からデータ取得開始日とって、基準を参考に貼り付け開始行を取得
B→貼り付け開始行を利用して切り取り貼り付け
C→Aから繰り替えす

みたいな普通の力技でなんとかしました。アドバイス貰ったのに全く生かせないでごめんなさい。

496:デフォルトの名無しさん
10/03/08 13:37:07
オートシェイプの検索アドインを業務の補助として作成中です。
一般的な実装はできましたが、よくばって検索値の前回値を使用できるようにしたい。
このような場合、前回値をどこに保存するのが一般的なのでしょうか?
excelマクロ・xlaならではの保存方法等ないでしょうか?

ないのであれば、別途保存用のシートに保存するか、またテキストファイル等に残します。
(あんまりエレガントじゃないきがして嫌です。)
ご存じの方おりましたらご享受ください。

497:デフォルトの名無しさん
10/03/08 13:58:58
>>495
ビンソートよりもバケット(バケツ)ソートという名前のほうが一般的かもしれない

内容は
日付のラベルが付いたビンに対応するデーターを放り込んで
詰め終わったら、端から順に取り出す

今回はデータがもともと順並びしてるので、
結果的にあなたがエクセル上でやったことと同じ作業ですね







498:デフォルトの名無しさん
10/03/08 14:06:04
>>496
Excelはシートに保存するのがエレガントだと思います。

499:デフォルトの名無しさん
10/03/08 15:39:54
なんらかの関数で引数となるシート名が存在するかチェックしてるんだが
シート数分Forでまわして同名シート見つけた時点でexitしてるんだけど
シート枚数が多くて使用者のPCスペックが低いためか時間が結構かかってきているんだが
なんかアドバイスない?
さしあたって事前にシート名チェックするのやめて
ダメならOn Error GoToで飛ばすようにしといたんだけど
もっといい方法あったら教えてください

500:デフォルトの名無しさん
10/03/08 15:57:25
シート名チェックってそんなに時間かかる処理だっけ?
何枚くらチェックしてるの?


501:デフォルトの名無しさん
10/03/08 16:13:38
シートの存在チェックは、何かやってみてon error gotoが一番速い

502:499
10/03/08 16:22:21
>>500
50枚くらいなんだけどモバイル用ノートで
CPUがセレロンなんだ・・・

>>501
やはりそうですよね
まず実行してみてだめだったらon error gotoで
具体的エラー内容を探すように変えていきます。

ありがとうございました。

503:デフォルトの名無しさん
10/03/08 18:02:04
>>502
ん、通じたのかな?例えばIsWorkSheetExist()みたいな関数を作って、その中で
on error goto NotExist
a = worksheet("Sheet1").range("a1").value // (*)
return true

NotExist:
return false

をやれってことで、「何かやって」は(*)の行の内容のこと。
いろんな関数にon error gotoをばらまけってことじゃないよ。

504:デフォルトの名無しさん
10/03/08 18:36:00
ADOつかってSQL使えば?
別にExcelのシートに対してもSQLで読み書きできるよ

505:デフォルトの名無しさん
10/03/08 20:14:29
こんばんは。どなたか詳しい方教えてくださいませんか。

エクセルのマクロでCSVファイルを開く→編集→保存(CSV形式)までを自動化しているのですが、

保存時の文字コードをS-JISではなくEUC-JPにして保存したいのです。

色々調べたんですが使えそうなのがなかったので・・。

506:デフォルトの名無しさん
10/03/08 21:02:08
保存した後で変換ツールに投げるとこまで自動化したらばどうよ

507:デフォルトの名無しさん
10/03/08 21:19:20
>>505
nkf.dll

508:デフォルトの名無しさん
10/03/08 21:48:31
ありがとうございます。

nkf.dll

を使ってみようと思います。

509:デフォルトの名無しさん
10/03/08 22:44:29
詳しい方に質問です。

ExcelVBAでシートに保護をかけて、変更して欲しくないセル(項目名など)
をロックしています。
ただ、シートに保護をかけてしまうと、テキストボックスや線オブジェクト、
図形オブジェクトがdisable?になってしまって使用できなくなります。

何か解決する方法はありますでしょうか?

510:デフォルトの名無しさん
10/03/09 00:33:02
保護の対象を細かく指定すりゃいいだろ

511:デフォルトの名無しさん
10/03/09 02:03:00
DrawingObjects:=False

512:デフォルトの名無しさん
10/03/09 14:40:04
XPで2003を使用しています。
VBA初心者で調べつつ作成しましたが、思った動作になりません。
どうかご教示下さい。

仕入先マスタのシートで仕入先CDを重複しないよう、入力後に
チェックをするようにしました。
(コードは次レスに貼ります)

【問題点】
If Not IsNumeric(Target.Value) Then Exit Sub
を入れると、ターゲットが複数行の場合は動作してくれません。

上記のコードを削除すると、複数行を挿入したり、連続しない複数行を
削除した時に重複したと認識されてしまいます。
(emptyかNullが重複?)

※つづきます

513:512
10/03/09 14:42:31
※つづきです

Dim maxRow As Long
Private Sub Worksheet_Change(ByVal Target As Range)
With Workbooks("仕入管理帳.xls").Worksheets("仕入先マスタ")

maxRow = .Cells(Rows.Count, 1).End(xlUp).Row
' If Not IsNumeric(Target.Value) Then Exit Sub
If Target.Column <> 1 Then Exit Sub
Set rngTarget = .Range("A2:A" & Target.Row - 1)
Set rngFind = rngTarget.Find(Target.Value, LookAt:=xlWhole)
If Not rngFind Is Nothing Then
If Target.Row <> rngFind.Row Then
Application.EnableEvents = False
MsgBox ("仕入先CDが重複しています"), vbExclamation
Target.ClearContents
Application.EnableEvents = True
End If

514:512
10/03/09 14:44:01
※最後です

Else
Set rngTarget = .Range("A" & Target.Row + 1 & ":A" & maxRow)
Set rngFind = rngTarget.Find(Target.Value, LookAt:=xlWhole)
If Not rngFind Is Nothing Then
If Target.Row <> rngFind.Row Then
Application.EnableEvents = False
MsgBox ("仕入先CDが重複しています"), vbExclamation
Target.ClearContents
Application.EnableEvents = True
End If
End If
End If
End With
End Sub

よろしくお願いします。

515:デフォルトの名無しさん
10/03/09 15:20:45
★5 レベルはどうあれ、ここはプログラマ用の板スレです。プログラマとは、自分でプログラムを組み
   コードを書く人の事なので、自分でやるきは全く無く、丸投げしようって人はお断りです。
   ヒントを貰えばあとは自力でなんとかしますって人のみどうぞ。

516:デフォルトの名無しさん
10/03/09 15:58:01
>>512
Targetに複数のセルが含まれるときは、こうすれば一つずつチェックできる
もちろんセルが1つでもエラーにはならない。Forの中を1回通るだけ
For Each c In Target
  If Not IsNumeric(c.Value) Then Exit Sub
Next c

517:512
10/03/09 16:25:12
>>516
出来ました!ありがとうございます!
1週間もあれこれ悩んでいたので、とても助かりました!!

518:デフォルトの名無しさん
10/03/09 20:57:12
Excelに
Craete AAA_TBL


一行改行されて
Craete BBB_TBL


一つのシートにこういうデータがあった場合、
crateAAA_TBL.sqlファイルを作成して
その中には
Craete AAA_TBL


crateBBB_TBL.sqlファイルを作成して
その中には
Craete BBB_TBL


と分割したいのですが
分かりますでしょうか?


519:デフォルトの名無しさん
10/03/09 21:01:46
わけわからん、なにが起きてるんだ


r=3
c=10
debug.print r , c

if r=3 and c=2 then
........
elseif r=3 and c=4 then
........
elseif r=3 and c=3 then
........
elseif r=3 and c=2 then
.......
elseif r=3 and c=10 then
debug.print r , c
debug.print "ここまで来た"
end if

実行結果

3 10



520:デフォルトの名無しさん
10/03/09 22:00:52
Sub test()
r = 3
c = 10
If r = 3 And c = 10 Then
Debug.Print r, c
Debug.Print "こないわけないだろ"
End If
End Sub

521:デフォルトの名無しさん
10/03/09 22:15:58
でも来ねえだもん、くまった


522:デフォルトの名無しさん
10/03/09 22:18:37
省略せずに丸ごとソースを貼るかエクスポートしてどこかにアップしろ

523:デフォルトの名無しさん
10/03/09 22:20:24
if r=3 and c=2 then

まったく同じ条件のIfが2つある。どうせほかにもタイプミスとかしてるに決まってる

524:デフォルトの名無しさん
10/03/09 22:44:29
デバッガでブレークポイント仕掛けてステップ実行しろよ

525:デフォルトの名無しさん
10/03/09 22:45:45
スマソ、自己解決した
頭のほうの if に不等号が入ってた
思い込みがあると目が見てても脳が見てないようだ

526:デフォルトの名無しさん
10/03/10 00:17:38
無能には良くあること

527:デフォルトの名無しさん
10/03/10 00:37:20
本当に>>523が正解だったとは

528:デフォルトの名無しさん
10/03/10 06:46:48
不等号が入ってたのは正解なので
タイプミスではありません
見のがしです
すいません、正確に言っておきたいもので(まげられないおんな風)


529:デフォルトの名無しさん
10/03/10 07:34:21
ソフトのこと全く知りません。
そんな僕でもがんばればVBAは習得できるでしょうか?


530:デフォルトの名無しさん
10/03/10 10:13:26
はじめから知ってるやつはいねえからそこは心配ない
あとはセンスしだい

531:デフォルトの名無しさん
10/03/10 11:19:08
>>530 ありがとうございます。
超入門の本を読んでいるのですが、読み終わったらもう少し専門書を購入し読みながら、
他の人の書いたプログラムを解読しつつ勉強しようと思うのですが、
このやり方でいいのでしょうか?

532:デフォルトの名無しさん
10/03/10 11:49:53
人が言葉を覚えるとき最初はオウム返しから始まるでしょ
プログラム言語もそれと似たようなもんですよ

書籍のサンプル等をガシガシ打ち込んでけば、身についていきます
コピペではあんまり身につきません、コピペが早くなるだけです
手打ちでがんばってください

人の書いたプログラムの解析は自分で作るよりも大変ですから、
そこから入るのは無理があるように思います




533:デフォルトの名無しさん
10/03/10 18:49:45
>>531
そういうやり方&他人のコード解読法で一回挫折したので、その後検定取りの為の勉強したな。(VBAエキスパートスタンダード)
アレは基本的に誰でも受かるように出来てるし、体系だって勉強出来るシステムになってるので基本は身に付くよ。

534:デフォルトの名無しさん
10/03/12 05:27:46
Excel VBAで、コピーしたセル範囲をペーストする時に列幅を変えずに貼り付ける事は
可能でしょうか。
コピーする内容にセル結合や罫線が含まれています。
どうかご教授下さい。

535:デフォルトの名無しさん
10/03/12 07:59:09
列をコピー&ペースト

536:デフォルトの名無しさん
10/03/12 12:00:19
>>534
まず普通にコピペしたあと、同じ場所にもう一度形式を選択して貼り付け→列幅

537:デフォルトの名無しさん
10/03/12 20:03:47
B3セルに"私は花子ですわ"、B4セルに"私は太郎ですよ"
があるとき、C3、C4セルにA列の2つの文字列を比較して違う部分を赤色にしたい。文字列の長さは同じとする。
で、次のように作ったんだけど、最後しか赤くならない。なんで?

Sub 文字列比較()
' 文字列比較 Macro
' マクロ記録日 : 2010/3/12 ユーザー名 : xp

Dim str1 As String
Dim str2 As String
Dim buf1 As String
Dim buf2 As String

str1 = Range("B3")
str2 = Range("B4")

For i = 1 To Len(str1)
buf1 = Mid(str1, i, 1)
buf2 = Mid(str2, i, 1)

If StrComp(buf1, buf2, vbTextCompare) = 0 Then
Range("c3").Value = Range("c3").Value & buf1
Range("c4").Value = Range("c4").Value & buf2
Else
Range("c3").Value = Range("c3").Value & buf1
Range("c4").Value = Range("c4").Value & buf2
Range("c3").Characters(i, 1).Font.ColorIndex = 3
Range("c4").Characters(i, 1).Font.ColorIndex = 3
End If
Next
End Sub

538:デフォルトの名無しさん
10/03/12 20:32:35
初歩的な質問ですがお願いします。

For
If xxx then
@の処理
Else
Aの処理
End If
Bの処理
Next

xxxの場合、@の処理をした場合には、Bの処理をせずに
次のfor文へ行きたいのですが、elseの中になにを書けばいいでしょうか?

539:デフォルトの名無しさん
10/03/12 20:42:58
>>537
マクロの記録でやってそうだからわかりそうなもんだけど、
 Range("c3").Characters(3, 1).Font.ColorIndex = 3 '花
 Range("c3").Characters(4 1).Font.ColorIndex = 3 '子
 Range("c3").Characters(7, 1).Font.ColorIndex = 3 'わ
は続けてやらないとダメだと思う。
  j = 0
For i = 1 To Len(str1)
If StrComp(Mid(str1, i, 1), Mid(str2, i, 1)) <> 0 Then
j = j + 1
ReDim Preserve s(1 To j)
s(j) = i
End If
Next
こんな感じで位置を先に取得してみては?

540:デフォルトの名無しさん
10/03/12 20:46:19
連レスすまん。
>>538
Aの処理の次にBを書いちゃダメなの?
For
 If xxx then
  @の処理
 Else
  Aの処理
  Bの処理
 End If
Next
それか、エスパーぎみに答えるとSelect caseを使うとか??

541:デフォルトの名無しさん
10/03/12 20:54:58
>>537
これの意味を勘違いしているような
Range("c3").Value = Range("c3").Value & buf1

セルc3の文字列を取出してbuf1の内容と文字列結合 → セルc3に上書き
この処理をすると これ以前にあった色指定が無効となる

つー事で
>>537を修正すると

Sub 文字列比較()
Dim str1 As String
Dim str2 As String
Dim buf1 As String
Dim buf2 As String

str1 = Range("B3")
str2 = Range("B4")
Range("c3").Value = str1
Range("c4").Value = str2

For i = 1 To Len(str1)
buf1 = Mid(str1, i, 1)
buf2 = Mid(str2, i, 1)

If StrComp(buf1, buf2, vbTextCompare) <> 0 Then
Range("c3").Characters(i, 1).Font.ColorIndex = 3
Range("c4").Characters(i, 1).Font.ColorIndex = 3
End If
Next
End Sub

542:538
10/03/12 21:03:38
>>540
ありがとうございます。


顔洗って出直してきます。

543:デフォルトの名無しさん
10/03/12 21:25:28
For
If xxx then
@の処理
Else
Aの処理
Bの処理
End If
Next

544:デフォルトの名無しさん
10/03/13 05:44:13
>>538
for x=1 to 100
if xxx _
then
@の処理
else
Aの処理
end if
Bの処理
Next
次のfor分の処理

こう書くと Bの処理をコメントアウトすればいいんじゃねということがわかるけど
Aの処理のあと”だけ”にBの処理をしたい、と言うこと?それとも
真ならば他の人のいうとおりだけど
Bの処理はAの処理の前にしたいのか、後にしたいのかが不明確ですよ
Bの処理がAの処理と独立ならば順不同だけど

545:デフォルトの名無しさん
10/03/13 06:06:19
VBAと関係ないね

546:デフォルトの名無しさん
10/03/13 11:50:59
Webクエリでデータを読み込んで加工するVBAを作成しています
データの込みこみを待ってから次の工程へ行くようにするにはどうすればよいですか?

547:デフォルトの名無しさん
10/03/13 15:10:25
>>546
Do While IEobject.Busy = True And IEobject.ReadyState <> 4

548:デフォルトの名無しさん
10/03/13 17:47:47
こみこみ ← なんかカワイイ

549:546
10/03/13 18:59:55
ありがとうございます

WebクエリとIEObjectの関係が分からないので、
もう少し調べます

550:デフォルトの名無しさん
10/03/13 20:40:49
Cells.Replace What:="1", Replacement:="1", LookAt:=xlPart, SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, ReplaceFormat:=False

0から9までの全角数字を半角数字に変換したいのですが
上記を10回書くよりも
これをfor文で回したいのですが
全角でというのか実現できません

教えてください


551:デフォルトの名無しさん
10/03/13 21:28:58
>>550
StrConv

552:デフォルトの名無しさん
10/03/13 22:07:45
すみません質問です

以下のような数字の置き換えをしたいのですがどのようにすればいいでしょうか?

<a name="1">  →  <a href="hoge">
<a name="2">  →  <a href="hoge">
<a name="3">  →  <a href="hoge">

<a name="9999">  →  <a href="hoge">

553:デフォルトの名無しさん
10/03/13 22:21:59
>>550
全角文字をループで扱うのはけっこう難しい。
文字コードを数値として扱う手もあるが、可読性が悪くなる。
プログラムの見栄えをすっきりさせたいなら、
配列に入れるか、置換のための関数を作るという手がある。
aryWhat = Array("0", "1", "2", ……

554:デフォルトの名無しさん
10/03/13 22:30:04
>>552
そういう場合は正規表現を使います。桁数の決まっていない数字は[0-9]+と書きます。
<a name=""[0-9]+"">
とすれば、これ1行で1から9999までのすべてが検索の対象になるので、これをhogeに置換します。

555:デフォルトの名無しさん
10/03/13 22:33:35
>>550
ヒント

Sub d()
  For i = 0 To 9
    Debug.Print i, StrConv(i, vbWide)
  Next
End Sub

556:デフォルトの名無しさん
10/03/13 23:34:43
>>554

ありがとうございます
すごく助かりました

557:デフォルトの名無しさん
10/03/14 11:41:57
別のエクセルファイルの標準モジュールに書いてある定数を読み込むには、
どうしたらいいでしょうか?

558:557
10/03/14 12:23:52
自己解決しました

559:デフォルトの名無しさん
10/03/14 16:11:54
NO 品名  価格 数量 金額
1  りんご 100  3  300
・・・

という連続したデータを

NO  1 ・・・
品名 りんご
産地 
数量 3 ・・・・

というふうに転記させる方法を教えてください。
転記先のフィールドは、元のフィールド名のものがない場合もあり、
逆に元のフィールドに無いものが転記先にあったりします。
また、転記元や転記先のフィールドの順番は、入れ替わる場合があります。
うまいやり方がありましたら教えてください。

560:デフォルトの名無しさん
10/03/14 17:34:39
>>559
どうかな。

1行目に作業用の空白行を追加する。

転記元の左端から1セルずつ値を読み、右に移動するループ(セルが空白になるまで)
 転記先の上端から1セルずつ値を読み、下に移動するループ
  if転記元の値と転記先の値が同じならば
   作業用の行に転記先のセル位置を記入

(ここまでで転記先のセル位置を取得)
A1 A2       A4
NO 品名  価格 数量 金額
1  りんご 100  3  300

あとは転記元のデータを1行ずつ処理。

561:デフォルトの名無しさん
10/03/14 17:39:05
>>559
新しいほうのデータの1レコード分の配列を用意する
古いほうのデーターから該当する配列の位置に読み込む
新しいデータへ配列から書き出す
以後レコード分繰り返し

562:デフォルトの名無しさん
10/03/14 18:22:14
別のシートにセルを一個ずつコピーしていけばいいのでは

563:デフォルトの名無しさん
10/03/14 18:48:01
おれだったらVLOOKUPでぱぱっと片付ける

564:480
10/03/14 22:45:10
Selection.PasteSpecial Paste:=xlPasteAll, Operation:=xlNone, SkipBlanks:=False, Transpose:=True

565:デフォルトの名無しさん
10/03/15 14:15:40
Excel2007
Workbooks.Add
で新規にワークブックを作成する際に
オプション→数式で自動になるように作成することってできませんか?
今の状態は手動になっています。


566:565
10/03/15 18:09:02
自己解決?
元のプログラムが入っているブックのオプションが手動になっていたので自動に変えたら
新しくできたブックも自動になってました。

なんか、自分自身をコピーして作ってるみたいな?(よく判りませんが w

567:デフォルトの名無しさん
10/03/16 11:39:35
WinXP Excel2003

Sub Input_Date(ByVal iDay As String)
ActiveCell.Value = CStr(iYear) _
& "/" & CStr(SpinButton1.Value) & "/" + iDay
ActiveCell.NumberFormatLocal = ComboBox1.Value
End Sub

いまのままだと何処のセルにも入力するようになっています。
指定したセルにのみ入力するよう変更したいのですが、どこを直せば良いでしょうか?


568:デフォルトの名無しさん
10/03/16 12:59:16
>>567
ActiveCell

569:デフォルトの名無しさん
10/03/16 16:40:50
VBAで、「どこぞのプロシージャ内で」、「別のプロシージャやイベントを設定・修正」するって出来る?
例えばBook/Formのロード時のイベントプロシージャで、
 btn_test_1
 btn_test_2
   …
 btn_test_10
…って感じのボタン10個について、forで回してそれぞれのClickイベントに同一の処理を上書きさせる、とか。
それともクラスモジュール作って〜な やり方しか無いのだろうか?
わかり辛い書き方でごめん。

570:デフォルトの名無しさん
10/03/16 17:54:28
2003、XPです。
株のシストレの計算をやらせるのに、ブック2枚を頻繁に行ったり来たりさせるようなモジュールはやはり相当遅くなるのでしょうか?

A:計算する元の四本値データだけ入ったブック。(シートが35枚あって、それだけで既に80MBのサイズ)
B:Aから計算結果だけを出力させるブック。

一枚に詰め込むべきか、複数枚に分けて管理すべきか・・・

571:デフォルトの名無しさん
10/03/16 18:11:19
>>570
単にデータを読み書きするだけなら大して遅くはならない。
いちいちSelectとかActivateとかやっちゃうと遅くなるんで、そうしないように注意してプログラムを作ればいい。
あとは、オブジェクト型変数とかWith句をできるだけ活用すること。
計算中は余分なイベントを止めるのもそこそこ効果がある。

572:デフォルトの名無しさん
10/03/16 18:14:14
>>569
質問の1行目だけ見ると答えはNO。
だけどたぶん、別の方法でできることをわかってないだけの気がする。

573:デフォルトの名無しさん
10/03/16 18:38:49
VBAでFX自動売買ソフトを作る事って可能でしょうか?

やりたい事

・業者orヤフー等からのレート取得
・発注機能

こんな感じです

574:デフォルトの名無しさん
10/03/16 18:42:34
可能です

575:デフォルトの名無しさん
10/03/16 18:46:01
是非作ってみたい
もしくはどなたかに作成していただきたいです

MT4だと業者に対応していないので・・


576:デフォルトの名無しさん
10/03/16 19:00:54
プログラムもわからんのにそんな事言っててもどうしようもないと思うが
んで、誰がただでやるわけww?

577:デフォルトの名無しさん
10/03/16 20:13:48
>>570
株価データの保存はDBに任せて、Excelは計算に専念させた方がスッキリすると思うけどね

578:デフォルトの名無しさん
10/03/16 20:17:59
Cells(1, 2) = Cells(1, 1)
というマクロを作ったのですが、Cells(1,1)の文字数が多すぎると
#VALUE!
というエラーが出てしまいます。
Cells(1, 1)の値を他のセルにコピーするにはどうすればいいのでしょうか。

579:デフォルトの名無しさん
10/03/16 20:27:13
まずは仕様書を書いてね
そしたら見積もり出すから


次ページ
最新レス表示
スレッドの検索
類似スレ一覧
話題のニュース
おまかせリスト
▼オプションを表示
暇つぶし2ch

4345日前に更新/253 KB
担当:undef