!extend:checked:vvvvv:1000:512
↑同じ内容を2行貼り付けるナリ
ExcelのVBAに関する質問スレナリ
コード書き込みや作成依頼もOKナリ
※前スレ
Excel VBA 質問スレ Part70
https://mevius.5ch.net/test/read.cgi/tech/1616072923/
Excel VBA 質問スレ Part71
https://mevius.5ch.net/test/read.cgi/tech/1621914481/
VIPQ2_EXTDAT: checked:vvvvv:1000:512:: EXT was configured
探検
Excel VBA 質問スレ Part72
■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん (スププ Sdaa-x2SP)
2021/07/18(日) 08:42:15.37ID:KskL7bEXd401デフォルトの名無しさん (スプッッ Sd33-mZ8Y)
2021/08/07(土) 13:00:42.96ID:slTH9qD1d402デフォルトの名無しさん (ワッチョイ 1b8c-kp8q)
2021/08/07(土) 16:23:06.08ID:IR0XtVNG0 Range("A1",rng).clear
Deleteじゃなくてクリアしたいならこれ
Deleteじゃなくてクリアしたいならこれ
403デフォルトの名無しさん (ワッチョイ 895f-jFcm)
2021/08/08(日) 08:21:09.95ID:ebb310K00 クラスでメインコードがすっきりとしていると機能追加も楽だね
404デフォルトの名無しさん (ワッチョイ 9b68-uW5m)
2021/08/08(日) 10:53:34.69ID:Yzbpuv/w0 コード書いてる時ってどんな気分ですか?
405デフォルトの名無しさん (ワッチョイ 6b68-Z6Ah)
2021/08/08(日) 10:59:34.31ID:5UdbG2j90 パズル解いてる気分
406デフォルトの名無しさん (スプッッ Sda3-Z6Ah)
2021/08/08(日) 11:24:54.00ID:XIbBz2idd めんどくせー
結果だけ欲しい
結果だけ欲しい
407デフォルトの名無しさん (ワッチョイ 1342-v6jM)
2021/08/08(日) 11:53:06.78ID:/228TsvP0 外注すればいいんじゃね
408デフォルトの名無しさん (ワッチョイ 13ad-ARME)
2021/08/08(日) 15:58:39.73ID:wvip2OSH0 たしかにパズルだな
409デフォルトの名無しさん (ワッチョイ 9332-mBWR)
2021/08/08(日) 16:26:56.76ID:gGBnC+Z00 美少女パズルRPG「パズルガールズ」
https://cdn.amz.appget.com/c/wp-content/uploads/2021/07/pg_8142870_1.jpg
https://cdn.amz.appget.com/c/wp-content/uploads/2021/07/pg_8142870_1.jpg
410デフォルトの名無しさん (ブーイモ MM85-hxGp)
2021/08/08(日) 16:30:40.54ID:N9yN2q6hM VBAなんて所詮操作の
411デフォルトの名無しさん (ブーイモ MM85-hxGp)
2021/08/08(日) 16:31:53.22ID:N9yN2q6hM 失礼
VBAなんて所詮操作の自動化なんで、慣れたらパズルというより手順書書くようなもんだ
どっちかというとワークシート関数を使いこなすほうがパズル
VBAなんて所詮操作の自動化なんで、慣れたらパズルというより手順書書くようなもんだ
どっちかというとワークシート関数を使いこなすほうがパズル
412デフォルトの名無しさん (ワッチョイ eb63-Lto6)
2021/08/08(日) 23:30:31.22ID:jh5zCN5Z0 ActiveWorkbookが入っているフォルダの名前の先頭に
ActiveWorkbookのSheets(1).Range("A2").Valueを付けたいです。
しかしフォルダ名の取得に失敗しています。
ActiveWorkbook.Path(フルパス)を\で区切った最後の文字列だと思いますが
もっと手短に取得する方法があったら教えてください。
ActiveWorkbookのSheets(1).Range("A2").Valueを付けたいです。
しかしフォルダ名の取得に失敗しています。
ActiveWorkbook.Path(フルパス)を\で区切った最後の文字列だと思いますが
もっと手短に取得する方法があったら教えてください。
413デフォルトの名無しさん (ワッチョイ d101-lHUs)
2021/08/09(月) 00:14:13.54ID:9VfepREK0 名前分解=split(名前,"\")(ubound(split(名前,"\"))
414デフォルトの名無しさん (ワッチョイ d101-lHUs)
2021/08/09(月) 00:43:14.90ID:9VfepREK0 あっカッコが足りない
415デフォルトの名無しさん (ワッチョイ 6bda-Z6Ah)
2021/08/09(月) 17:35:43.32ID:gGnrAdRU0 ださっ
416デフォルトの名無しさん (ワッチョイ d1ba-yyuh)
2021/08/10(火) 18:56:58.22ID:9fiWluCI0 FileSystemObject使えばいいんじゃね?
ファイルそのものを操作しないならちょっと面倒に感じるかもだけど
ファイルそのものを操作しないならちょっと面倒に感じるかもだけど
417デフォルトの名無しさん (ワッチョイ 9b68-uW5m)
2021/08/10(火) 21:44:06.51ID:dMuyff760 やや冗長だけど、fsoは使って損は無いと思う。¥とsplitは頭が疲れる
Sub foo()
Set fso = CreateObject("Scripting.FileSystemObject")
Set mybook = fso.getfile(ThisWorkbook.FullName)
Set mybook_parent = mybook.parentfolder
Header = ActiveWorkbook.Sheets(1).Range("A2").Value
Debug.Print Header & mybook_parent.Name
End Sub
Sub foo()
Set fso = CreateObject("Scripting.FileSystemObject")
Set mybook = fso.getfile(ThisWorkbook.FullName)
Set mybook_parent = mybook.parentfolder
Header = ActiveWorkbook.Sheets(1).Range("A2").Value
Debug.Print Header & mybook_parent.Name
End Sub
418デフォルトの名無しさん (ブーイモ MM95-3gcB)
2021/08/10(火) 23:53:30.63ID:Xm+HKu32M splitが楽だと思うが、、、
419デフォルトの名無しさん (ワッチョイ 6b8f-+f9r)
2021/08/10(火) 23:57:50.14ID:plMJ/ypm0 >>404
締切のある「数独」
締切のある「数独」
420デフォルトの名無しさん (ワッチョイ 0101-YN7O)
2021/08/11(水) 02:05:15.42ID:yV4dFjvN0 >>413
ubound(split は禁じ手って言われてる
ubound(split は禁じ手って言われてる
421デフォルトの名無しさん (ブーイモ MM85-Z6Ah)
2021/08/11(水) 02:19:37.21ID:T0yXhT3EM422デフォルトの名無しさん (ワッチョイ 895f-jFcm)
2021/08/11(水) 04:35:09.41ID:KlHs/LBx0 InstrRevじゃだめなん?
423デフォルトの名無しさん (JP 0H73-tV31)
2021/08/11(水) 05:55:28.37ID:LQvUe8o6H 文字列として取得したいだけならまだしも、フォルダ名変えたいんでしょ?
普通にFileSystemObject使った方がいいよ
普通にFileSystemObject使った方がいいよ
424デフォルトの名無しさん (ワッチョイ 312f-Lto6)
2021/08/11(水) 12:03:15.14ID:pcBI0cgA0 なんにしても、開いてるエクセルのあるフォルダの名前とか変えれんと思うのだがのう
425デフォルトの名無しさん (ブーイモ MM33-52IO)
2021/08/11(水) 12:29:18.95ID:oEEdpHhhM フォルダ作って、開いてないファイルは移動して、開いてるファイルは新しいフォルダーに名前を付けて保存ってして、
最後に要らんフォルダとファイルを消せばリネームしたように見える(見えるだけ)
最後に要らんフォルダとファイルを消せばリネームしたように見える(見えるだけ)
426デフォルトの名無しさん (ワッチョイ 9b68-uW5m)
2021/08/11(水) 12:30:50.00ID:N26Fs5+x0 20180811_フォルダ名
みたいにバックアップつくル目的かと思ってた
みたいにバックアップつくル目的かと思ってた
427デフォルトの名無しさん (ワッチョイ 312f-Lto6)
2021/08/11(水) 13:00:28.54ID:pcBI0cgA0 リネームすらできないのに、どうやって自分自身を含むフォルダを削除できるんだ?
428デフォルトの名無しさん (ラクッペペ MM8b-OMgf)
2021/08/11(水) 13:04:20.40ID:dnSnLDjMM 名前をつけて保存
429デフォルトの名無しさん (ブーイモ MM8b-3gcB)
2021/08/11(水) 13:08:03.81ID:jh4/giPJM 非同期でスクリプトを実行してから
自分を閉じる
スクリプトの動作は一定時間スリープしてからフォルダごと削除
で、できる?
自分を閉じる
スクリプトの動作は一定時間スリープしてからフォルダごと削除
で、できる?
430デフォルトの名無しさん (ワッチョイ 312f-Lto6)
2021/08/11(水) 13:19:34.76ID:pcBI0cgA0 基本的にはそれでできるだろうけど、
権限の問題とか、ファイルがルートに置かれてたりしたときとか、考慮点はいっぱいある
権限の問題とか、ファイルがルートに置かれてたりしたときとか、考慮点はいっぱいある
431デフォルトの名無しさん (アウアウウー Sa55-FoHg)
2021/08/11(水) 13:24:26.65ID:4Gud1KwJa 自分が書いたコードを公開すればいいのに、みなさんよくこの質問を答える気になるね
432デフォルトの名無しさん (ワッチョイ 6bda-Z6Ah)
2021/08/11(水) 15:19:39.84ID:BgXnPp0P0 そう思うなら自分が書いたコードを公開すればいいのに
433デフォルトの名無しさん (ワッチョイ b168-Z6Ah)
2021/08/11(水) 16:01:47.79ID:wST2jK7f0 的外れ
434デフォルトの名無しさん (ラクッペペ MM8b-OMgf)
2021/08/11(水) 18:18:12.44ID:6659knn7M 答える方もテキトーだから気にするな
435デフォルトの名無しさん (アウアウウー Sa55-zfXN)
2021/08/11(水) 22:13:22.02ID:0mcLwEZRa 的を得る?的を射る?
436デフォルトの名無しさん (ワッチョイ 9b68-uW5m)
2021/08/11(水) 22:20:07.30ID:N26Fs5+x0 今は両方正解とも言われてるな
437デフォルトの名無しさん (ワッチョイ 0101-NW/4)
2021/08/11(水) 23:18:26.09ID:/u/X/l7G0 射的場では、景品が的です。
射貫けば、ば的が得られるのです。
というムチャクチャな言い訳で、得るもOKになったらしいですぞ。
射貫けば、ば的が得られるのです。
というムチャクチャな言い訳で、得るもOKになったらしいですぞ。
438デフォルトの名無しさん (ワッチョイ a15f-nI4z)
2021/08/11(水) 23:51:27.40ID:MV8X3c1h0 教養ないやつのせいで誤用が標準化されるのか
439デフォルトの名無しさん (ワッチョイ 9b68-uW5m)
2021/08/11(水) 23:57:08.62ID:N26Fs5+x0 「新しい:あたらしい」
も、
元々は「あらたしい」が正しい
今更これに対して教養がどうとか思わんでしょ。そのうち慣れる
も、
元々は「あらたしい」が正しい
今更これに対して教養がどうとか思わんでしょ。そのうち慣れる
440デフォルトの名無しさん (ブーイモ MMeb-Z6Ah)
2021/08/12(木) 00:28:12.75ID:AcVN/mcWM 「全然」の用法は一周して元に戻ったけどな
441デフォルトの名無しさん (ワッチョイ 0101-NW/4)
2021/08/12(木) 00:36:07.89ID:2S4isd+w0442デフォルトの名無しさん (ワッチョイ 9b68-uW5m)
2021/08/12(木) 00:44:37.62ID:BTMS1DN70443デフォルトの名無しさん (ブーイモ MM8b-3gcB)
2021/08/12(木) 00:46:04.06ID:XfbSLdwiM いや、それも
「をいる」
より
「をえる」
のほうが言いやすいからと解釈できますよ
「い」は口を横に広げないといけないかど
「え」ならそれほど広げる必要もなくその後の「る」にも移行しやすいからね
「をいる」
より
「をえる」
のほうが言いやすいからと解釈できますよ
「い」は口を横に広げないといけないかど
「え」ならそれほど広げる必要もなくその後の「る」にも移行しやすいからね
444デフォルトの名無しさん (スプッッ Sda3-Z6Ah)
2021/08/12(木) 01:26:40.50ID:YbO1i5Cqd 「こんにちは」と書いて「こんにちわ」と発音するのも、knifeをナイフと読むのも、言いやすいように変化しただけ
言葉ってのはそういうもん
言葉ってのはそういうもん
445デフォルトの名無しさん (スプッッ Sda3-Z6Ah)
2021/08/12(木) 01:30:00.55ID:jC6xQX8qd >>438
世界中の言語、習慣、伝統や文化のほとんどは、教養のないやつが作り上げた物なんだぜ
世界中の言語、習慣、伝統や文化のほとんどは、教養のないやつが作り上げた物なんだぜ
446デフォルトの名無しさん (JP 0H73-tV31)
2021/08/12(木) 02:58:07.28ID:aOGRiEATH 的もらえたとして、もらうやついるの?
447デフォルトの名無しさん (ワッチョイ 9b68-uW5m)
2021/08/12(木) 07:17:08.83ID:BTMS1DN70 >>446
縁日の射的
縁日の射的
448デフォルトの名無しさん (オイコラミネオ MMed-lHUs)
2021/08/12(木) 08:25:03.59ID:F2ZBInFgM じゃあknifeは昔
クゥナイフとか言われてたのか
クゥナイフとか言われてたのか
449デフォルトの名無しさん (JP 0H85-NW/4)
2021/08/12(木) 09:03:50.69ID:KOJd5FjgH450デフォルトの名無しさん (スフッ Sd33-Lto6)
2021/08/12(木) 09:08:47.23ID:6jf0e9cQd 「延々と」を「永遠と」と書いたり言ったりする間違いが増えてて気になる
451デフォルトの名無しさん (アウアウウー Sa55-FoHg)
2021/08/12(木) 10:25:30.66ID:8wOIyJEba スレと全く関係ない話で
452デフォルトの名無しさん (ワッチョイ b168-Z6Ah)
2021/08/12(木) 10:31:28.13ID:JfgsXMu40 fightとかどう読んでたんだよ
ファイグフトかよ
ハードルが敷居に変わりつつある
フンイキがフインキに変わりつつある
ファイグフトかよ
ハードルが敷居に変わりつつある
フンイキがフインキに変わりつつある
453デフォルトの名無しさん (ワッチョイ 9b68-uW5m)
2021/08/12(木) 11:06:43.36ID:BTMS1DN70 >>452
そのとおり。昔は全て表記通りの発音だった。
欧米圏内は色々な言語が複雑に混じり合った経緯があるので、「なんで?」と考えるとキリないぞ
更に言うとネットやテレビが台頭してからは言語は固定されるだろう、と学者は予想していたけどあんまりそうでもないようだ
そのとおり。昔は全て表記通りの発音だった。
欧米圏内は色々な言語が複雑に混じり合った経緯があるので、「なんで?」と考えるとキリないぞ
更に言うとネットやテレビが台頭してからは言語は固定されるだろう、と学者は予想していたけどあんまりそうでもないようだ
454デフォルトの名無しさん (スフッ Sd33-Z6Ah)
2021/08/12(木) 11:29:35.78ID:cpovNsRqd ネットで声の大きいバカが目立てるようになったおかげで、間違いの広がる速度がむしろ加速してる
ウィルスやワクチンの誤解もひどいもんだし
ウィルスやワクチンの誤解もひどいもんだし
455デフォルトの名無しさん (アウアウウー Sa55-TjhZ)
2021/08/12(木) 11:32:55.00ID:stPdQEKya あの…VBA…
456デフォルトの名無しさん (ブーイモ MMeb-NW/4)
2021/08/12(木) 11:37:28.29ID:3EGHE4wmM 言葉の変化を認めないやつはRight関数も500年前の発音でアルァイギーエッテー関数と読めよ
457デフォルトの名無しさん (JP 0H85-Z6Ah)
2021/08/12(木) 11:39:34.06ID:KOJd5FjgH 次の質問どうぞ
458デフォルトの名無しさん (ラクッペペ MM8b-IWqQ)
2021/08/12(木) 12:31:29.35ID:uGYsB1RKM ファンクション(Function)
↓
ファンスウ
↓
ハンスウ(函数)
↓
カンスウ(関数)
↓
ファンスウ
↓
ハンスウ(函数)
↓
カンスウ(関数)
459デフォルトの名無しさん (JP 0H73-tV31)
2021/08/12(木) 14:58:41.40ID:wFbxLk6vH 万葉仮名も太古の昔はそのまま読んでたらしいしな
460デフォルトの名無しさん (ワッチョイ d101-lHUs)
2021/08/12(木) 15:14:57.51ID:4wn9NucC0 ナイフはそのうち
「ナイ」になるのかな
「ナイ」になるのかな
461デフォルトの名無しさん (ワッチョイ b168-Z6Ah)
2021/08/12(木) 15:16:18.65ID:JfgsXMu40 サイフはサイか
日本語やんけー
日本語やんけー
462デフォルトの名無しさん (ワッチョイ 9b68-uW5m)
2021/08/12(木) 15:21:53.11ID:BTMS1DN70 >>454
ネットは大分マシ。すぐにそれは変ですよって指摘できるからな
昔は大名が変な言い間違いをしていたらそれが臣下に広まって、地域一体のおかしな方言になった
ワクチンの誤情報もネットがなかったらもっとひどいことになっていただろう
ネットは大分マシ。すぐにそれは変ですよって指摘できるからな
昔は大名が変な言い間違いをしていたらそれが臣下に広まって、地域一体のおかしな方言になった
ワクチンの誤情報もネットがなかったらもっとひどいことになっていただろう
463デフォルトの名無しさん (アウアウウー Sa55-FoHg)
2021/08/12(木) 17:42:00.13ID:Fj2kkZVUa ひとのコードにケチをつけるつもりはまったくないけど
上にあった「名前分解=split(名前,"\")(ubound(split(名前,"\"))」ってのを実際に書きたい場合
自分は他人が見る見ないにかかわらず「a = split(名前,"\")」と「名前分解=a(ubound(a))」の
2行に分けるような感じで書いてるけど1行にする人がおおいのかね?
上にあった「名前分解=split(名前,"\")(ubound(split(名前,"\"))」ってのを実際に書きたい場合
自分は他人が見る見ないにかかわらず「a = split(名前,"\")」と「名前分解=a(ubound(a))」の
2行に分けるような感じで書いてるけど1行にする人がおおいのかね?
464デフォルトの名無しさん (オイコラミネオ MMed-lHUs)
2021/08/12(木) 17:53:53.44ID:XQI2fayvM そっちのほうがいいね
465デフォルトの名無しさん (アウアウウー Sa55-TjhZ)
2021/08/12(木) 18:01:08.04ID:tY2of2ova 1ヵ月後の自分は他人なので…
丁寧に書けるなら絶対その方がいい
丁寧に書けるなら絶対その方がいい
466289 (スフッ Sd33-RGvM)
2021/08/12(木) 18:29:35.92ID:FVU2afn4d 前スレ848です
最後の報告です
スレ汚しすいませんでした
その後
マクロ廃止後業務量が増えまくってあほがヒステリーを起こし
スラックで延々とケンカを売られ続けた
あまりにもブーメランを投げてくるので華麗に避けてたらあほ激怒
仕事を辞めると言い出した
課長はその言葉お嬉々として受け止めていた
結局のところ仕事が終わらず、マクロを使うことになったよ
あほが辞めるのは嬉しいけど、本当に自分が正しいのかよくわからなくなり
ちょっと鬱気味になっている
結論はマクロお人に共有すべきじゃなかったと思う
最後の報告です
スレ汚しすいませんでした
その後
マクロ廃止後業務量が増えまくってあほがヒステリーを起こし
スラックで延々とケンカを売られ続けた
あまりにもブーメランを投げてくるので華麗に避けてたらあほ激怒
仕事を辞めると言い出した
課長はその言葉お嬉々として受け止めていた
結局のところ仕事が終わらず、マクロを使うことになったよ
あほが辞めるのは嬉しいけど、本当に自分が正しいのかよくわからなくなり
ちょっと鬱気味になっている
結論はマクロお人に共有すべきじゃなかったと思う
467デフォルトの名無しさん (アウアウウー Sa55-r06d)
2021/08/12(木) 18:58:40.91ID:Fj2kkZVUa468デフォルトの名無しさん (ワッチョイ b168-Z6Ah)
2021/08/12(木) 19:09:35.66ID:JfgsXMu40469デフォルトの名無しさん (ブーイモ MM33-52IO)
2021/08/12(木) 19:30:26.41ID:J6mXolxSM470デフォルトの名無しさん (ワッチョイ 618e-effB)
2021/08/12(木) 19:36:16.05ID:Gdq8XFU10 >>466
死ねよ
死ねよ
471デフォルトの名無しさん (アウアウウー Sa55-FoHg)
2021/08/12(木) 19:43:55.65ID:Fj2kkZVUa472デフォルトの名無しさん (ワッチョイ 9b68-uW5m)
2021/08/12(木) 23:17:39.27ID:BTMS1DN70 >>466
いつもの流れだから気にすんな
いつもの流れだから気にすんな
473デフォルトの名無しさん (ワッチョイ 6eda-oCel)
2021/08/13(金) 02:15:07.67ID:fQVKfGt/0 >>466
まだ終わってない
まだ終わってない
474デフォルトの名無しさん (ワンミングク MM92-4yzW)
2021/08/13(金) 03:37:00.81ID:NVit/nDVM >>466
こういう人ってたかがマクロを少し作れるだけで自分が会社を経営してると思い込む馬鹿ばっかだよ
こういう人ってたかがマクロを少し作れるだけで自分が会社を経営してると思い込む馬鹿ばっかだよ
475デフォルトの名無しさん (ワッチョイ 62f0-/m/d)
2021/08/13(金) 09:23:59.80ID:Dh6ZDsQC0 すみません
VBA初心者です
下記プログラムはB1とB2に任意の数値を入れると
A5〜A100に数値から数値の間の数字が打ちあがります
一度入力したら2回目はA5からA100の数値を手動で削除
しなければなりません
B1に数値を新たに入力したら自動でクリアされれば
手動で削除しなくていいのですがコードが書けないで困ってます
どなたか詳しい方いましたらご教授ください
Private Sub Worksheet_Change(ByVal Target As Range)
On Error Resume Next
If Target.Address <> "$B$2" Then Exit Sub
If Range("B1").Value = "" Then
Exit Sub
End If
Range("A5:A100").Clear
Dim cnt As Long
Dim i As Long, j As Long
j = 0
cnt = Target.Value - Target.Offset(-1).Value
For i = 5 To cnt + 5
Cells(i, 1) = Target.Offset(-1).Value + j
Cells(i, 1).NumberFormatLocal = "@"
j = j + 1
Next i
End Sub
VBA初心者です
下記プログラムはB1とB2に任意の数値を入れると
A5〜A100に数値から数値の間の数字が打ちあがります
一度入力したら2回目はA5からA100の数値を手動で削除
しなければなりません
B1に数値を新たに入力したら自動でクリアされれば
手動で削除しなくていいのですがコードが書けないで困ってます
どなたか詳しい方いましたらご教授ください
Private Sub Worksheet_Change(ByVal Target As Range)
On Error Resume Next
If Target.Address <> "$B$2" Then Exit Sub
If Range("B1").Value = "" Then
Exit Sub
End If
Range("A5:A100").Clear
Dim cnt As Long
Dim i As Long, j As Long
j = 0
cnt = Target.Value - Target.Offset(-1).Value
For i = 5 To cnt + 5
Cells(i, 1) = Target.Offset(-1).Value + j
Cells(i, 1).NumberFormatLocal = "@"
j = j + 1
Next i
End Sub
476デフォルトの名無しさん (オイコラミネオ MM49-AL+r)
2021/08/13(金) 09:29:56.69ID:7J82GjQPM >>474
噂の同僚もこんなこと言ってそうだな
噂の同僚もこんなこと言ってそうだな
477デフォルトの名無しさん (ワッチョイ 9901-ic7f)
2021/08/13(金) 09:40:28.79ID:IVydqk9y0 VBAで数値計算をやらないといけないから、VBAの仕様を一通り学ぼうと思って書籍で勉強しているんだけど、
VBAで数値計算する意味がわからんわ
VBAで数値計算するメリットってファイルの入出力くらいしかないだろ・・・
VBAで数値計算する意味がわからんわ
VBAで数値計算するメリットってファイルの入出力くらいしかないだろ・・・
478デフォルトの名無しさん (ワッチョイ 7168-NTPF)
2021/08/13(金) 09:57:08.98ID:lG5axGIx0479デフォルトの名無しさん (オイコラミネオ MM49-AL+r)
2021/08/13(金) 10:08:41.85ID:7J82GjQPM >>477
逆に少し複雑になったら
並べ替えやvlookup用に変な数字が所狭しと並んだり
式もシートもぐちゃぐちゃになったり
行を増やすごとに式をいちいちコピペしないといけなかったり式のコピペ漏れの危険もある関数でやるメリットのほうがよくわからん
関数使っても問題ないのはマジで足し算掛け算レベルの簡単なものだけだろ
逆に少し複雑になったら
並べ替えやvlookup用に変な数字が所狭しと並んだり
式もシートもぐちゃぐちゃになったり
行を増やすごとに式をいちいちコピペしないといけなかったり式のコピペ漏れの危険もある関数でやるメリットのほうがよくわからん
関数使っても問題ないのはマジで足し算掛け算レベルの簡単なものだけだろ
480デフォルトの名無しさん (ワッチョイ 0668-MFFZ)
2021/08/13(金) 10:09:11.78ID:zvWaH7NU0 >>475
b1かb2以外で終了、に変更
Excel入ってないPCだから試してないけど、多分動くと思う
If Target.Address <> "$B$2" Then Exit Sub
↓
If not(Target.Address = "$B$2" or Target.Address = "$B$1") Then Exit Sub
b1かb2以外で終了、に変更
Excel入ってないPCだから試してないけど、多分動くと思う
If Target.Address <> "$B$2" Then Exit Sub
↓
If not(Target.Address = "$B$2" or Target.Address = "$B$1") Then Exit Sub
481デフォルトの名無しさん (ブーイモ MM6d-H+bG)
2021/08/13(金) 10:14:40.50ID:/ejQKQyrM482デフォルトの名無しさん (ワッチョイ 0668-MFFZ)
2021/08/13(金) 10:23:05.89ID:zvWaH7NU0483デフォルトの名無しさん (アウアウウー Saa5-/KFf)
2021/08/13(金) 10:37:15.01ID:5J5GXzoka テーブル機能は関数、VBAともに相性いいからとりあえずテーブルにするところから始めればいいんじゃないかな
484デフォルトの名無しさん (アウアウウー Saa5-++7W)
2021/08/13(金) 11:50:40.69ID:c6dMXYo0a >>475
判定をなおしてみました。こんな感じはどうでしょう。
If Target.Address = "$B$1" Then
Range("A5:A100").Clear
Exit Sub
ElseIf Target.Address = "$B$2" Then
If Range("B1").Value = "" Then
Exit Sub
End If
Else
Exit Sub
End If
判定をなおしてみました。こんな感じはどうでしょう。
If Target.Address = "$B$1" Then
Range("A5:A100").Clear
Exit Sub
ElseIf Target.Address = "$B$2" Then
If Range("B1").Value = "" Then
Exit Sub
End If
Else
Exit Sub
End If
485デフォルトの名無しさん (ワッチョイ 9901-2/6I)
2021/08/13(金) 14:43:20.07ID:MQNa+Oeo0 >>475
「B1が変更」かつ「B2が入力済み」の場合にも処理されるようにするのはどうでしょうか。
後、B1B2が数値である保証がないのも気になりました。
冒頭(Early Returnの部分)を
If Target.Address <> "$B$2" and Target.Address <> "$B$1" Then Exit Sub
If (VarType(Range("B1").Value) <> vbDouble) Then Exit Sub
If (VarType(Range("B2").Value) <> vbDouble) Then Exit Sub
に修正し、
Target.Value - Target.Offset(-1).Value
等の部分を具体的にRange("B1")の様にしてみて下さい。
「B1が変更」かつ「B2が入力済み」の場合にも処理されるようにするのはどうでしょうか。
後、B1B2が数値である保証がないのも気になりました。
冒頭(Early Returnの部分)を
If Target.Address <> "$B$2" and Target.Address <> "$B$1" Then Exit Sub
If (VarType(Range("B1").Value) <> vbDouble) Then Exit Sub
If (VarType(Range("B2").Value) <> vbDouble) Then Exit Sub
に修正し、
Target.Value - Target.Offset(-1).Value
等の部分を具体的にRange("B1")の様にしてみて下さい。
486デフォルトの名無しさん (ワッチョイ c2da-oCel)
2021/08/13(金) 16:54:07.44ID:HPpKMPwN0 いまだにテーブル機能を表のレイアウトの見栄えよくする機能だと思っている人いるんだなマジで。
興味ないとそんなもんだよね
興味ないとそんなもんだよね
487デフォルトの名無しさん (アウアウウー Saa5-/KFf)
2021/08/13(金) 17:27:51.79ID:Ko30HHoCa Vlookupなんてテーブルありきの仕様(範囲可変対応、速度、列指定等…)だし、
VBA使う時はForで範囲の中の値をループ処理するのはテーブル使うのが1番完結かつ読み手に伝わりやすい(と思う)
興味ない人は触れることもないんだろうなぁと思うと寂しいね
VBA使う時はForで範囲の中の値をループ処理するのはテーブル使うのが1番完結かつ読み手に伝わりやすい(と思う)
興味ない人は触れることもないんだろうなぁと思うと寂しいね
488デフォルトの名無しさん (ワッチョイ 62f0-/m/d)
2021/08/13(金) 18:51:34.24ID:Dh6ZDsQC0 VBA達人の皆さんありがとうございます
早速試してみます
皆さんはどのように勉強されたのですか?
VBA2年目ですがまだまだ初心者から脱却できません
早速試してみます
皆さんはどのように勉強されたのですか?
VBA2年目ですがまだまだ初心者から脱却できません
489デフォルトの名無しさん (ワッチョイ c2da-oCel)
2021/08/13(金) 18:51:53.98ID:HPpKMPwN0 まだ良いよ
見栄えよくすると思い込んでいて、何でもかんでもテーブルに変換する同僚がいるから
出力でそれやられると見辛い
見栄えよくすると思い込んでいて、何でもかんでもテーブルに変換する同僚がいるから
出力でそれやられると見辛い
490デフォルトの名無しさん (ワッチョイ 0668-MFFZ)
2021/08/13(金) 19:17:27.00ID:zvWaH7NU0491デフォルトの名無しさん (ワッチョイ 8101-AL+r)
2021/08/13(金) 20:37:12.04ID:fD7XP3Na0 変数を日本語にすると頭に入りやすい
492デフォルトの名無しさん (ワッチョイ 62f0-/m/d)
2021/08/13(金) 20:55:03.16ID:Dh6ZDsQC0493デフォルトの名無しさん (ワッチョイ 62f0-/m/d)
2021/08/13(金) 20:57:12.23ID:Dh6ZDsQC0494デフォルトの名無しさん (ワッチョイ 9901-ic7f)
2021/08/13(金) 21:57:30.74ID:IVydqk9y0 >>479
やっぱりどう考えてもVBAで数値計算って無理がありそうですよね
数値計算自体も偏微分方程式の解を求めたり、モンテカルロで期待値を求めたりするので、結構重いです・・・
学生なんで確信を持って言えないのですが、恐らく就職希望している業界がVBAとc++がメインなのでVBAで数値計算をできるようになっておく必要があると思います。
とりあえずまだ時間があるので、一度自分でVBAで書いてみてからデメリットを実感して見ようかと思います
やっぱりどう考えてもVBAで数値計算って無理がありそうですよね
数値計算自体も偏微分方程式の解を求めたり、モンテカルロで期待値を求めたりするので、結構重いです・・・
学生なんで確信を持って言えないのですが、恐らく就職希望している業界がVBAとc++がメインなのでVBAで数値計算をできるようになっておく必要があると思います。
とりあえずまだ時間があるので、一度自分でVBAで書いてみてからデメリットを実感して見ようかと思います
495デフォルトの名無しさん (ワッチョイ 9901-ic7f)
2021/08/13(金) 21:59:38.88ID:IVydqk9y0496デフォルトの名無しさん (ワッチョイ 71e4-gilQ)
2021/08/13(金) 22:15:24.05ID:al2VsHhL0 その分野には詳しくないんだが、不向きなのに何故VBAを数値計算に使うんだ?
エクセルならVBA使わずとも関数とかソルバーで出来るんじゃない?
エクセルならVBA使わずとも関数とかソルバーで出来るんじゃない?
497デフォルトの名無しさん (ワッチョイ 0668-MFFZ)
2021/08/13(金) 22:24:34.19ID:zvWaH7NU0498デフォルトの名無しさん (オイコラミネオ MMd6-Lo6P)
2021/08/13(金) 23:20:47.22ID:WIfN9845M 賑わってるね
499デフォルトの名無しさん (ワッチョイ 8101-AL+r)
2021/08/14(土) 00:11:33.82ID:p2FjIi+P0 >>497
あっ…なるほど(察し
あっ…なるほど(察し
500デフォルトの名無しさん (ワッチョイ 8232-/m/d)
2021/08/14(土) 00:32:25.73ID:8xoU1q0D0 夏季休暇に突入したぜウェーイ!
501デフォルトの名無しさん (アウアウウー Saa5-5/Wf)
2021/08/14(土) 03:50:50.70ID:2+Zp3qYIa c++とvbaを両方とも使うのありますよ
ターボファンの3次元ブレード図面の自動生成をする為に
autoCAD用APIをc++使ってdirectXのシェーダーでやり
流体計算はcudaの並列計算する一方で
ユーザーインターフェースはExcelVBAで寸法入力させるんですよ
ターボファンの3次元ブレード図面の自動生成をする為に
autoCAD用APIをc++使ってdirectXのシェーダーでやり
流体計算はcudaの並列計算する一方で
ユーザーインターフェースはExcelVBAで寸法入力させるんですよ
■ このスレッドは過去ログ倉庫に格納されています
