C# と VB.NET の質問掲示板
ASP.NET、C++/CLI、Java 何でもどうぞ
掲示板トップ
C# と VB.NET 入門
新規作成
利用方法
ツリー表示
トピック表示
ランキング
記事検索
過去ログ
ログ内検索
キーワードを複数指定する場合は 半角スペース で区切ってください。
検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
[返信]をクリックすると返信ページへ移動します。
キーワード
/
検索条件
/
(AND)
(OR)
検索範囲
/
(現在のログ)
(全過去ログ)
(過去ログ1)
(過去ログ2)
(過去ログ3)
(過去ログ4)
(過去ログ5)
(過去ログ6)
(過去ログ7)
(過去ログ8)
(過去ログ9)
(過去ログ10)
(過去ログ11)
(過去ログ12)
(過去ログ13)
(過去ログ14)
(過去ログ15)
(過去ログ16)
(過去ログ17)
(過去ログ18)
(過去ログ19)
(過去ログ20)
(過去ログ21)
(過去ログ22)
(過去ログ23)
(過去ログ24)
(過去ログ25)
(過去ログ26)
(過去ログ27)
(過去ログ28)
(過去ログ29)
(過去ログ30)
(過去ログ31)
(過去ログ32)
(過去ログ33)
(過去ログ34)
(過去ログ35)
(過去ログ36)
(過去ログ37)
(過去ログ38)
(過去ログ39)
(過去ログ40)
(過去ログ41)
(過去ログ42)
(過去ログ43)
(過去ログ44)
(過去ログ45)
(過去ログ46)
(過去ログ47)
(過去ログ48)
(過去ログ49)
(過去ログ50)
(過去ログ51)
(過去ログ52)
(過去ログ53)
(過去ログ54)
(過去ログ55)
(過去ログ56)
(過去ログ57)
(過去ログ58)
(過去ログ59)
(過去ログ60)
(過去ログ61)
(過去ログ62)
(過去ログ63)
(過去ログ64)
(過去ログ65)
(過去ログ66)
(過去ログ67)
(過去ログ68)
(過去ログ69)
(過去ログ70)
(過去ログ71)
(過去ログ72)
(過去ログ73)
(過去ログ74)
(過去ログ75)
(過去ログ76)
(過去ログ77)
(過去ログ78)
(過去ログ79)
(過去ログ80)
(過去ログ81)
(過去ログ82)
(過去ログ83)
(過去ログ84)
(過去ログ85)
(過去ログ86)
(過去ログ87)
(過去ログ88)
(過去ログ89)
(過去ログ90)
(過去ログ91)
(過去ログ92)
(過去ログ93)
(過去ログ94)
(過去ログ95)
(過去ログ96)
(過去ログ97)
(過去ログ98)
(過去ログ99)
(過去ログ100)
(過去ログ101)
(過去ログ102)
(過去ログ103)
(過去ログ104)
(過去ログ105)
(過去ログ106)
(過去ログ107)
(過去ログ108)
(過去ログ109)
(過去ログ110)
(過去ログ111)
(過去ログ112)
(過去ログ113)
(過去ログ114)
(過去ログ115)
(過去ログ116)
(過去ログ117)
(過去ログ118)
(過去ログ119)
(過去ログ120)
(過去ログ121)
(過去ログ122)
(過去ログ123)
(過去ログ124)
(過去ログ125)
(過去ログ126)
(過去ログ127)
(過去ログ128)
(過去ログ129)
(過去ログ130)
(過去ログ131)
(過去ログ132)
(過去ログ133)
(過去ログ134)
(過去ログ135)
(過去ログ136)
(過去ログ137)
(過去ログ138)
(過去ログ139)
(過去ログ140)
(過去ログ141)
(過去ログ142)
(過去ログ143)
(過去ログ144)
(過去ログ145)
(過去ログ146)
(過去ログ147)
(過去ログ148)
(過去ログ149)
(過去ログ150)
(過去ログ151)
(過去ログ152)
(過去ログ153)
(過去ログ154)
(過去ログ155)
(過去ログ156)
(過去ログ157)
(過去ログ158)
(過去ログ159)
(過去ログ160)
(過去ログ161)
(過去ログ162)
(過去ログ163)
(過去ログ164)
(過去ログ165)
(過去ログ166)
(過去ログ167)
(過去ログ168)
(過去ログ169)
(過去ログ170)
(過去ログ171)
(過去ログ172)
(過去ログ173)
(過去ログ174)
(過去ログ175)
(過去ログ176)
(過去ログ177)
(過去ログ178)
(過去ログ179)
強調表示
/
ON
(自動リンクOFF)
結果表示件数
/
20件
30件
40件
50件
100件
記事No検索
/
ON
大文字と小文字を区別する
全過去ログを検索
ヒット / 9件
(1-9 を表示)
<<
0
>>
■56056
Re[1]: VB2010でSelectAllのクリア方法
□投稿者/ 魔界の仮面弁士 -
(2010/12/24(Fri) 16:09:28)
■
No56051
(ペリカン さん) に返信
> VB2010でWebBrowser1.Document.ExecCommand("SelectAll", False, Type.Missing)で選択をした場合の
> 選択クリアの方法を教えて下さい。
> VB6では
> WebBrowser1.ExecWB OLECMDID_SELECTALL, OLECMDEXECOPT_DODEFAULT
ExecWB と execCommand は別物ですよ。
VB6 でも、document.execCommand は利用できますし、
.NET でも .ActiveXInstance.ExecWB を呼び出せます。
> WebBrowser1.Document.ExecCommand("CLEARSELECTION"", False, Type.Missing)
"Unselect" コマンドですね。
WebBrowser1.Document.ExecCommand("Unselect", False, Nothing)
http://msdn.microsoft.com/en-us/library/ms537432.aspx
execCommand のコマンドの一覧はこちら。各コマンドのリンクをたどると、showUI 引数などの扱いも記載されています。
http://msdn.microsoft.com/en-us/library/ms533049.aspx
ExecWB のコマンド一覧はこちら。
http://msdn.microsoft.com/en-us/library/ms691264.aspx
http://msdn.microsoft.com/en-us/library/aa741315.aspx
記事No.56051 のレス /過去ログ94より /
関連記事表示
削除チェック/
■83942
WebBrowserのスクリプトエラー
□投稿者/ JOY -
(2017/04/26(Wed) 11:49:46)
分類:[VB.NET/VB2005 以降]
VB2008で、WebBrowserコントロールを使ったWindowsアプリを作成しました。
ただ、WebBrowserでjQueryを使用しているサイトを表示しようとすると、
「jQueryが定義されていない」というようなスクリプトエラーが出ます。
WebBrowserはIEのエンジンが使われていると聞いたことがありますが、
自分のPC(Windows7)のIE(IE11)では問題なく表示されているので、
WebBrowserのIEは古いものなのでしょうか?
親記事 /過去ログ143より /
関連記事表示
削除チェック/
■93174
自然ソートを高速で行う方法
□投稿者/ NNN -
(2019/11/25(Mon) 21:42:23)
分類:[.NET 全般]
自然ソートに関してですが、
https://wiki.dobon.net/index.php?.NET%A5%D7%A5%ED%A5%B0%A5%E9%A5%DF%A5%F3%A5%B0%B8%A6%B5%E6%2F111
ここにコードが掲載されています。
いくつか方法がありますが、
StrCmpLogicalWを使用する方法 以外の方法だと
Explorerのソート順と一致しないことがあるため、
StrCmpLogicalWを使用する方法 を使っています。
ただ、ファイル数が多いとかなり時間がかかってしまいます。
この方法はForループで何度も二つのファイル間で比較を行うわけですが、
何度もStrCmpLogicalW関数を呼び出すのは時間がかかるため
最初に全ファイルをDoubleのような変数に変換して、
後から、順番に比較するようなことをしたいのですが
そのようなことは可能でしょうか?
他にもっと高速な方法がありましたらお教えくださいませ。
親記事 /過去ログ161より /
関連記事表示
削除チェック/
■93180
Re[1]: 自然ソートを高速で行う方法
□投稿者/ furu -
(2019/11/26(Tue) 09:40:07)
■
No93174
(NNN さん) に返信
> 自然ソートに関してですが、
>
https://wiki.dobon.net/index.php?.NET%A5%D7%A5%ED%A5%B0%A5%E9%A5%DF%A5%F3%A5%B0%B8%A6%B5%E6%2F111
>
> ただ、ファイル数が多いとかなり時間がかかってしまいます。
>
> この方法はForループで何度も二つのファイル間で比較を行うわけですが、
リンクのサンプルでは、Forループ使っていないようですが
ソートは自作?
アルゴリズムは?
記事No.93174 のレス /過去ログ161より /
関連記事表示
削除チェック/
■93185
Re[2]: 自然ソートを高速で行う方法
□投稿者/ はまぐり -
(2019/11/26(Tue) 20:41:58)
■
No93174
(NNN さん) に返信
シュワルツ変換を使ったソートならLINQのOrderByを使えば簡単にできます
StrCmpLogicalWの実装に従ってソートキーを正規化するのは
StrCmpLogicalWのソースコードが公開されてれば頑張りようもありますけど
ブラックボックスなのでどうにもできないような・・・
目的は高速化で手段としてシュワルツ変換をしようとしておられるわけですよねー
StrCmpLogicalW関数はそんなに遅いのかなと思って試してみましたけど1億回呼んでも10秒でした、結構速いです
シュワルツ変換は複数のフィールドでソートするときには効果的ですが今回はあまり効果なさそうな気がします
気になるほどの時間がかかっているとするなら原因は違うところにあるんじゃないかなと
ディスクのIOが遅いとか、furuさんの観点は鋭いと思いました
記事No.93174 のレス /過去ログ161より /
関連記事表示
削除チェック/
■93359
Re[3]: 自然ソートを高速で行う方法
□投稿者/ NNN -
(2019/12/07(Sat) 12:11:42)
ありがとうございます。
返信遅れました
furuさんの仰る通り、
バブルソートを使っているのが原因でした
ちなみに自分でクイックソートプログラムを作って比較してみたのですが、
以下のように'Array.Sortの方が20%程度速かったのです。
'バブルソート 7390ミリ秒
'クイックソート 58ミリ秒
'Array.Sort 49ミリ秒
'Array.Sortはシュワルツ変換を使っているのでしょうか?
あるいは、同じクイックソートだけれど、中はC++のような高速な言語で走っているので
高速なのでしょうか?
記事No.93174 のレス /過去ログ161より /
関連記事表示
削除チェック/
■93361
Re[4]: 自然ソートを高速で行う方法
□投稿者/ キングダム -
(2019/12/07(Sat) 20:42:59)
■
No93359
(NNN さん) に返信
Array.SortはkeySelectorを引数にとらないので
シュワルツ変換は行われていないはずです
コンパレータを渡さなければネイティブコードが呼ばれるみたいです
コンパレータを渡したらマネージコードでソートしてますね(GitHubのソースコード見ました)
クイックソートの実装が違えば20%くらいの
差はあるんじゃないかなと思います
・ピボットの選び方を工夫する
・交換の仕方を工夫する
・再帰をループに置き換える
・件数が少なかったら挿入ソートに切り替える
・再帰が深くなったらヒープソートに切り替える
クイックソートの実装ではこのような方法があるんでそのあたりの実装の違いで
20%くらいは差が出るんじゃないかなと思います
速いソートを実装するならそういった最適化をしつつ
マルチスレッドで処理するようにするとArray.Sortを超えられると思います
記事No.93174 のレス /過去ログ161より /
関連記事表示
削除チェック/
■95642
Re[2]: クラス変数へのポインタアクセス
□投稿者/ 774RR -
(2020/08/28(Fri) 14:39:34)
もっとコメントするなら C++ では . の結合のほうが単項 * より強いので、
*image.cols は *(image.cols) と解釈されるので . の左側はクラス型でないエラー
image->cols と書くか (*image).cols ならたぶん質問者の意図通りっス
記事No.95637 のレス /過去ログ165より /
関連記事表示
削除チェック/
■97202
Re[1]: dataGridViewにて改行コードがある場合のみ改行
□投稿者/ 魔界の仮面弁士 -
(2021/04/13(Tue) 14:52:54)
■
No97200
(馬渕誠一 さん) に返信
> どう書けばいいでしょうか?
過去ログ
No78277
に、似たような話題がありましたね。
http://bbs.wankuma.com/index.cgi?mode=al2&namber=78277&KLOG=133
> // dataGridView1
(抜粋)
> AutoSizeColumnsMode = DisplayedCells
> AutoSizeRowsMode = DisplayedCells
この設定は「セル内容を書き換えた時」や「ソート時」などには処理されますが、
スクロール時には考慮されないことに注意が必要です。
たとえば DisplayedCells モードにおいて、
先頭行の任意の列に「ABCDEFGHIJKLMNOPQRSTUVWXYZ」と記入して自動リサイズされた後、
垂直スクロールして、その先頭行を領域外に押し出したとします。
その後、同列の任意行に「12345」という短文を書くと、列幅が自動縮小されます。
この状態で、スクロールして先頭行に戻った場合、列幅は狭いままです。
そのため、長文がセル内に収まりきらない状態になってしまいます。
> 文字が収まるようにしたい
パフォーマンスとのトレードオフにはなりますが、DisplayedCells モードのまま
スクロールにも追従しようとするなら、こういう手もあります。
dataGridView1.Scroll += delegate
{
dataGridView1.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.DisplayedCells);
dataGridView1.AutoResizeRows(DataGridViewAutoSizeRowsMode.DisplayedCells);
};
このケースは、スクロールする度にセルサイズが変わることになるのが欠点です。
水平・垂直スクロールの両方が必要なケースでは使い勝手が悪いかもしれません。
スクロールに影響を与えないよう、最大のセルサイズを優先する形にする場合は
AllCells や AllCellsExceptHeaders モードを使うようにしてみてください。
このモードは全セルが計測対象になるため、行数・列数が増えると
DisplayedCells モードよりも負荷が上がります。
AllCells の欠点は、殆どのセルが短文で、一つのセルだけが長文だった場合、
長文セルにつられて、他のセルが余白ばかりになってしまうという点ですね。
どちらが良いかはケースバイケース。
また、予期せぬ位置で改行されてしまうワードラップの問題については、
下記のような対処方法があります。下記は AllCells モードの例です。
private void Form1_Load(object sender, EventArgs e)
{
dataGridView1.EditMode = DataGridViewEditMode.EditOnEnter;
dataGridView1.ReadOnly = false;
dataGridView1.DataSource = null;
dataGridView1.AutoGenerateColumns = false;
dataGridView1.RowCount = 100;
dataGridView1.ColumnCount = 5;
dataGridView1.DefaultCellStyle.WrapMode = DataGridViewTriState.True;
dataGridView1.AlternatingRowsDefaultCellStyle.WrapMode = DataGridViewTriState.True;
dataGridView1.AllowUserToResizeColumns = false;
dataGridView1.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.None;
dataGridView1.AllowUserToResizeRows = false;
dataGridView1.AutoSizeRowsMode = DataGridViewAutoSizeRowsMode.None;
dataGridView1.CellEndEdit += (target, arg) =>
{ // 最大幅を設定してからリサイズしなおす
dataGridView1.Columns[arg.ColumnIndex].Width = 0x10000;
dataGridView1.AutoResizeRow(arg.RowIndex, DataGridViewAutoSizeRowMode.AllCells);
dataGridView1.AutoResizeColumn(arg.ColumnIndex, DataGridViewAutoSizeColumnMode.AllCells);
};
dataGridView1.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells);
dataGridView1.AutoResizeRows(DataGridViewAutoSizeRowsMode.AllCells);
}
記事No.97200 のレス /過去ログ168より /
関連記事表示
削除チェック/
<<
0
>>
パスワード/
-
Child Tree
-