!extend:checked:vvvvv:1000:512
次スレを立てる時は↑を2行冒頭に書くこと(1行分は消えて表示されない為)
「どんなにくだらないC#プログラミングやVisual C#の使い方に関する質問でも誰かが優しくレスをしてくれるスレッド」です。
他のスレッドでは書き込めないような低レベルな質問、質問者自身なんだか意味がよく分からない質問、
ググろうにもキーワードが分からないなど、勇気をもって書き込んでください。
内容に応じて他スレ・他板へ行くことを勧められることがあります。ご了承下さい。
なお、テンプレが読めない回答者、議論をしたいだけの人は邪魔なので後述のC#相談室に移動して下さい。
C#に関係の無い話題や荒らしの相手や罵倒レスや酔っぱらいレスはやめてください
>>980を踏んだ人は新スレを建てて下さい。>>980が無理な場合、話し合って新スレを建てる人を決めて下さい。
■前スレ
ふらっと C#,C♯,C#(初心者用) Part145
https://mevius.5ch.net/test/read.cgi/tech/1570446977/
■関連スレ
C#, C♯, C#相談室 Part95
https://mevius.5ch.net/test/read.cgi/tech/1508168482/
■コードを貼る場合は↓を使いましょう。
http://ideone.com/
https://dotnetfiddle.net/
■情報源
https://docs.microsoft.com/ja-jp/dotnet/standard/class-libraries
https://docs.microsoft.com/ja-jp/dotnet/csharp/language-reference/index
https://docs.microsoft.com/en-us/dotnet/standard/class-libraries
http://referencesource.microsoft.com/
・Insider.NET > .NET TIPS - @IT
https://www.atmarkit.co.jp/ait/subtop/features/dotnet/dotnettips_index.html
・DOBON.NET .NET Tips
https://dobon.net/vb/dotnet/index.html
VIPQ2_EXTDAT: checked:vvvvv:1000:512:: EXT was configured
探検
ふらっと C#,C♯,C#(初心者用) Part146
■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん (ワッチョイ 9f0b-Fgt1)
2019/12/11(水) 22:12:11.28ID:d09CciDz017デフォルトの名無しさん (ブーイモ MM13-RobM)
2019/12/13(金) 17:33:03.63ID:f86+e1mZM あとは 50 音を全パターン書いてね。
ただし注意点があって、長いワードは短いワードよりも (例えば「ちょ」は「ち」よりも) 先に並べるんだ。
そうしないと短いワードが先に部分マッチしてしまう。
ただし注意点があって、長いワードは短いワードよりも (例えば「ちょ」は「ち」よりも) 先に並べるんだ。
そうしないと短いワードが先に部分マッチしてしまう。
18デフォルトの名無しさん (スップ Sd22-aD55)
2019/12/13(金) 17:47:39.93ID:s9cNxHbdd テーブル作る前提なら始めからdictionary作ればよくね?
19デフォルトの名無しさん (スップ Sd22-aD55)
2019/12/13(金) 17:49:41.61ID:s9cNxHbdd 一文字ずつ正規表現でマッチしてたらとんでもなく時間食いそうだな
姓名の変換くらいならどうとでもなるだろうけど
姓名の変換くらいならどうとでもなるだろうけど
20デフォルトの名無しさん (ブーイモ MMdb-RobM)
2019/12/13(金) 18:16:48.88ID:RrhzxBUdM21デフォルトの名無しさん (ワッチョイ c788-aD55)
2019/12/13(金) 18:33:49.64ID:KAf60mjk0 まったくスッキリしてない
圧倒的にswitchが早い
圧倒的にswitchが早い
22デフォルトの名無しさん (ブーイモ MMdb-RobM)
2019/12/13(金) 18:44:01.44ID:8Ub64SZCM >21
それは感情論だな。計時してみてくれよ。
Perl, JavaScript, Java, C# で正規表現を使うこと 30 年弱になるけど、パターンの複雑さによらず、正規表現が目に見えて遅いということはなかったな。
アセンブラでゴリゴリに最適化したものと比べたら遅いだろうが、同じ言語のユーザー定義関数より目に見えて遅いことはまあないと思うよ。
それは感情論だな。計時してみてくれよ。
Perl, JavaScript, Java, C# で正規表現を使うこと 30 年弱になるけど、パターンの複雑さによらず、正規表現が目に見えて遅いということはなかったな。
アセンブラでゴリゴリに最適化したものと比べたら遅いだろうが、同じ言語のユーザー定義関数より目に見えて遅いことはまあないと思うよ。
23デフォルトの名無しさん (スププ Sd02-qWAV)
2019/12/13(金) 18:48:06.09ID:04gYwNVod これならDictionary作るわ
24デフォルトの名無しさん (ブーイモ MMdb-RobM)
2019/12/13(金) 18:51:56.74ID:8Ub64SZCM25デフォルトの名無しさん (ワッチョイ c788-aD55)
2019/12/13(金) 19:49:57.23ID:KAf60mjk0 2文字置換を考慮したらスッキリは書けなかった
すまんこ
こんなクソみたいなコードでもregexよりは数倍早い
https://ideone.com/c7ILX4
頭良い人がもっとスッキリしたコード書いてくれそう
長文のほうがreplaceは不利だろうから数千文字にしたけどそれでも余裕
速度気にしないならregexで良いと思う
すまんこ
こんなクソみたいなコードでもregexよりは数倍早い
https://ideone.com/c7ILX4
頭良い人がもっとスッキリしたコード書いてくれそう
長文のほうがreplaceは不利だろうから数千文字にしたけどそれでも余裕
速度気にしないならregexで良いと思う
26デフォルトの名無しさん (ワッチョイ c788-aD55)
2019/12/13(金) 19:58:53.60ID:KAf60mjk0 最終文字が2文字置換対象じゃないときにsubstringで範囲外例外出るわ
条件1個追加しといて
条件1個追加しといて
27デフォルトの名無しさん (スップ Sd22-aD55)
2019/12/13(金) 20:57:05.81ID:9t702OJgd 小さい「っ」が未対応なことに気付いた
これ正規表現でもめんどいね
正規表現ならっを無視してreplaceした後に1個ずつ置換かなぁ
これ正規表現でもめんどいね
正規表現ならっを無視してreplaceした後に1個ずつ置換かなぁ
28デフォルトの名無しさん (ワッチョイ e752-RobM)
2019/12/13(金) 21:07:14.03ID:M1n71JyZ0 多少簡略化したロジックで計測してみた。
マッチ文字列が 1 文字固定なら、ユーザー定義関数の方が正規表現より 8 倍速かったが、1 〜 2 文字可変なら所要時間は同じ。
パターンマッチの文字列長が可変・複雑になるとそれをハンドルするための分岐が増えるせいでユーザー定義関数は遅くなる。
もちろん置換をかけるオリジナル文字列の文字出現パターン&確率にもよる。
チューニングするなら C やアセンブラで書くべきだし、C# で書くなら正規表現で簡潔に書けるほうがよいのでは?
マッチ文字列が 1 文字固定なら、ユーザー定義関数の方が正規表現より 8 倍速かったが、1 〜 2 文字可変なら所要時間は同じ。
パターンマッチの文字列長が可変・複雑になるとそれをハンドルするための分岐が増えるせいでユーザー定義関数は遅くなる。
もちろん置換をかけるオリジナル文字列の文字出現パターン&確率にもよる。
チューニングするなら C やアセンブラで書くべきだし、C# で書くなら正規表現で簡潔に書けるほうがよいのでは?
29デフォルトの名無しさん (ワッチョイ e752-RobM)
2019/12/13(金) 21:12:22.88ID:M1n71JyZ030デフォルトの名無しさん (ワッチョイ ef63-aD55)
2019/12/13(金) 21:22:02.14ID:VulPdUq80 どうあがいてもregexは遅くないという結論にしたいみたいだけど
string単体で見ても遅いのにregexが遅くないわけがない
簡潔に書くならregexがスマートなパターンが多いのは分かってるよw
処理速度求められるパーサーなんかではまずregexなんか使わない
遅いと言っても数万文字の処理が何万回も必要とかでなければ気にするようなレベルではないので問題ないなら素直にregex使ったほうが良いよ
25ですでにそう言ってるしね
string単体で見ても遅いのにregexが遅くないわけがない
簡潔に書くならregexがスマートなパターンが多いのは分かってるよw
処理速度求められるパーサーなんかではまずregexなんか使わない
遅いと言っても数万文字の処理が何万回も必要とかでなければ気にするようなレベルではないので問題ないなら素直にregex使ったほうが良いよ
25ですでにそう言ってるしね
31デフォルトの名無しさん (ワッチョイ e752-RobM)
2019/12/13(金) 21:26:23.93ID:M1n71JyZ0 あるいはワンショットで置換するなら、下記のようなパターンを使って後方参照し、第1マッチ文字列が空でないなら、第2マッチ文字列の置換先の1文字目に置換するとか。
(っ?)(あ|い|う|え|お|か|き|く|け|こ)
(っ?)(あ|い|う|え|お|か|き|く|け|こ)
32デフォルトの名無しさん (アウアウイー Sa1f-f14Z)
2019/12/13(金) 21:26:56.26ID:yXJ+I/RUa 「ンョ゛ハー ゛」みたいなのが来た時の対応とか考え出すと仕様肥大化するだろうなあ
ひらがなカタカナ両対応とか、半角カナとか、
長音の代わりにハイフン使いだした場合とか
「ヴァッソ」とか
テストパターン考えるのも厄介そうだね
ひらがなカタカナ両対応とか、半角カナとか、
長音の代わりにハイフン使いだした場合とか
「ヴァッソ」とか
テストパターン考えるのも厄介そうだね
33デフォルトの名無しさん (ワッチョイ 5f01-uKDx)
2019/12/13(金) 21:30:11.16ID:0IHjBlJG0 LALRを受理するジェネレータ書いたことがあるんだけど、状態表の大きさは字句解析のほうが遥かに大きくなるのが普通みたいですよ。
字句解析と構文解析は一つの表にまとめられるのに、なぜ分けるのかというのが最初の疑問だけど、なぜか答えが載ってる本が無い。
実際にやってみると表の大きさが爆発的に大きくなるからでした。
状態機械は分けられる箇所があるなら積極的に分けたほうが効率的になるようです。
字句解析と構文解析は一つの表にまとめられるのに、なぜ分けるのかというのが最初の疑問だけど、なぜか答えが載ってる本が無い。
実際にやってみると表の大きさが爆発的に大きくなるからでした。
状態機械は分けられる箇所があるなら積極的に分けたほうが効率的になるようです。
34デフォルトの名無しさん (ワッチョイ e752-RobM)
2019/12/13(金) 21:30:12.87ID:M1n71JyZ0 >>30
文字列操作だからもちろん絶対的には遅いよ。
C# で書いたユーザー定義関数と比べたときに正規表現が相対的にそんなに不利かといったらそうではないだろうという予想を立てただけで。実際測ったら同等だったわけだけど。
文字列操作だからもちろん絶対的には遅いよ。
C# で書いたユーザー定義関数と比べたときに正規表現が相対的にそんなに不利かといったらそうではないだろうという予想を立てただけで。実際測ったら同等だったわけだけど。
35デフォルトの名無しさん (ワッチョイ 5701-2Uq8)
2019/12/13(金) 21:30:26.83ID:7oWhly6q0 日経だったか「むかっっ」という促音が
重なる文章というか記事があったな
重なる文章というか記事があったな
36デフォルトの名無しさん (ワッチョイ 5f01-uKDx)
2019/12/13(金) 21:33:36.65ID:0IHjBlJG0 字句解析におけるNFA対DFAというのも最初に気になる部分です。
結論から言うと、NFAの選択は十分に考慮できるはずです。
僕も最初はDFAにこだわっていました。
でも、字句解析は表が大きくなりがちです。
特にregex並みの便利機能を組み込もうとすると、とても大きくなります。
たいていはNFAで十分かと思います。
結論から言うと、NFAの選択は十分に考慮できるはずです。
僕も最初はDFAにこだわっていました。
でも、字句解析は表が大きくなりがちです。
特にregex並みの便利機能を組み込もうとすると、とても大きくなります。
たいていはNFAで十分かと思います。
37デフォルトの名無しさん (ワッチョイ 5f01-uKDx)
2019/12/13(金) 21:37:02.69ID:0IHjBlJG0 ちなみに、DFAにこだわる理由は、多くの本がDFAのほうが効率的と述べているからです。
みんなそうだと思います。
最悪のケースではその通りですし、最悪のケースを考慮するのはセキュリティにも関わります。
でも最悪のケースはめったになく、たいていはNFAで十分で、たいていは効率的だと思います。
みんなそうだと思います。
最悪のケースではその通りですし、最悪のケースを考慮するのはセキュリティにも関わります。
でも最悪のケースはめったになく、たいていはNFAで十分で、たいていは効率的だと思います。
38デフォルトの名無しさん (ワッチョイ ef63-aD55)
2019/12/13(金) 21:39:05.74ID:VulPdUq80 >>34
その同等だったっていうコード貼ってくれない?
25で貼ったコードで1文字2文字の比率変えてもregex側が常に3〜4倍くらい遅いんだよね
古い.NETだとsubstringが遅いとかあった気がするんだけどその影響じゃないよね?
その同等だったっていうコード貼ってくれない?
25で貼ったコードで1文字2文字の比率変えてもregex側が常に3〜4倍くらい遅いんだよね
古い.NETだとsubstringが遅いとかあった気がするんだけどその影響じゃないよね?
39デフォルトの名無しさん (ワッチョイ e752-RobM)
2019/12/13(金) 21:42:16.88ID:M1n71JyZ040デフォルトの名無しさん (ワッチョイ 62b0-DoXq)
2019/12/13(金) 21:42:32.85ID:f+S2ArPq041デフォルトの名無しさん (ワッチョイ e752-RobM)
2019/12/13(金) 21:51:25.19ID:M1n71JyZ0 >>38
コードは長すぎて多分アップできないと思う。
やっていることは switch 式を2 文字マッチの場合と 1 文字マッチの場合で 2 種類つくり、残文字列が 2 文字以上あるなら前者にかける (破棄パターン _ => で後者を呼び出す)、1文字なら後者にかけ、インデックスを進めるだけ。
置換後文字列の連結には StringBuilder 使っているし、メソッド呼び出しは AggressiveInlining している。ユーザー定義関数を意図的に遅くするようなことはしていない。
1文字あるいは2文字の切り出しに Substring 使っているけど、それが遅いのかな?
コードは長すぎて多分アップできないと思う。
やっていることは switch 式を2 文字マッチの場合と 1 文字マッチの場合で 2 種類つくり、残文字列が 2 文字以上あるなら前者にかける (破棄パターン _ => で後者を呼び出す)、1文字なら後者にかけ、インデックスを進めるだけ。
置換後文字列の連結には StringBuilder 使っているし、メソッド呼び出しは AggressiveInlining している。ユーザー定義関数を意図的に遅くするようなことはしていない。
1文字あるいは2文字の切り出しに Substring 使っているけど、それが遅いのかな?
42デフォルトの名無しさん (アウアウイー Sa1f-f14Z)
2019/12/13(金) 21:52:27.04ID:yXJ+I/RUa ローマ字変換でばっとググってみた
お勉強用ならJavaScriptで書かれてるこれを理解しながらC#に移植するのがよさそうかな
ソースコードも簡潔だし悪くなさそう
https://www.pandanoir.info/entry/2016/03/29/190000
とにかく動けばいいというならMicrosoftが配ってるらしい「Japanese Kana Conversion Library」?でもこんなの使ったことないや
お勉強用ならJavaScriptで書かれてるこれを理解しながらC#に移植するのがよさそうかな
ソースコードも簡潔だし悪くなさそう
https://www.pandanoir.info/entry/2016/03/29/190000
とにかく動けばいいというならMicrosoftが配ってるらしい「Japanese Kana Conversion Library」?でもこんなの使ったことないや
43デフォルトの名無しさん (ワッチョイ a201-VrMI)
2019/12/13(金) 22:00:14.44ID:+9OE4qBy0 ンボマはmboma
ンバッペはmbappe
だからね
練習用なんだろうけど
簡単に見えても文字変換を自力でやるのはかなり面倒くさい
ンバッペはmbappe
だからね
練習用なんだろうけど
簡単に見えても文字変換を自力でやるのはかなり面倒くさい
44デフォルトの名無しさん (ワッチョイ a201-VrMI)
2019/12/13(金) 22:10:51.66ID:+9OE4qBy0 正規表現のほうが単純文字列比較より遅いのは当たり前
1文字比較の場合に単純比較と同等になるような
最適化が施されてるエンジン積んでれば数倍とかの差はつかない
少し古いバージョンのブラウザのJSのなら平気で10倍近い差が出てた
でもその差がUXに影響を与えるようなユースケースはそう多くはない
ちなみにstringのswitch caseは数が増えると
.NET Core以前は内部的にDictionary使うみたいよ
.NET Coreもhash比較するのは同じだけどDictionaryをアロケートしない方法にしてるらしい
1文字比較の場合に単純比較と同等になるような
最適化が施されてるエンジン積んでれば数倍とかの差はつかない
少し古いバージョンのブラウザのJSのなら平気で10倍近い差が出てた
でもその差がUXに影響を与えるようなユースケースはそう多くはない
ちなみにstringのswitch caseは数が増えると
.NET Core以前は内部的にDictionary使うみたいよ
.NET Coreもhash比較するのは同じだけどDictionaryをアロケートしない方法にしてるらしい
45デフォルトの名無しさん (ワッチョイ ef63-aD55)
2019/12/13(金) 22:12:49.12ID:VulPdUq80 >>39
これで見えるかね
ttps://ideone.com/c7ILX4
このコードはswitchじゃなくDictionaryでやった
おそらくswitchのほうがこれより早くなるか最適化で同程度になるはず
switch版までは作るのめんどい
配列の境界値チェックも遅い要因なのでできるだけチェックが発生しないのが望ましい
このコードでは2文字変換したときに境界値チェックが入ってしまうので2文字変換比率が高いと性能が悪くなる
2文字変換ばかりにしてもregexよりは早い
これで見えるかね
ttps://ideone.com/c7ILX4
このコードはswitchじゃなくDictionaryでやった
おそらくswitchのほうがこれより早くなるか最適化で同程度になるはず
switch版までは作るのめんどい
配列の境界値チェックも遅い要因なのでできるだけチェックが発生しないのが望ましい
このコードでは2文字変換したときに境界値チェックが入ってしまうので2文字変換比率が高いと性能が悪くなる
2文字変換ばかりにしてもregexよりは早い
46デフォルトの名無しさん (ワッチョイ e752-RobM)
2019/12/13(金) 22:38:36.62ID:M1n71JyZ0 >>45
ありがとう。週末に評価してみる。
switch より Dictionary の方が処理性能がぶれない気がする。ハッシュで検索がワンショットに決まるから。switch は if カスケードを通ることで前スレで議論したパイプライン処理の影響を受けるため、処理速度がデータに強く依存する。
そんなわけでこの件の性能はコードの書き方 (チューニング含む)、データ、環境にかなり依存すると思う。
これは価値観の問題なのでみなが同じように考えるとは思わないが、正規表現で 3 - 4 倍程度の性能悪化なら、ユーザー定義関数よりチューニングより正規表現を私は採用する。
10 倍の悪化なら用途によっては考える。(パターンが複雑・多岐の場合) 正規表現は開発効率と保守性が 10 倍よいと思うので。
ありがとう。週末に評価してみる。
switch より Dictionary の方が処理性能がぶれない気がする。ハッシュで検索がワンショットに決まるから。switch は if カスケードを通ることで前スレで議論したパイプライン処理の影響を受けるため、処理速度がデータに強く依存する。
そんなわけでこの件の性能はコードの書き方 (チューニング含む)、データ、環境にかなり依存すると思う。
これは価値観の問題なのでみなが同じように考えるとは思わないが、正規表現で 3 - 4 倍程度の性能悪化なら、ユーザー定義関数よりチューニングより正規表現を私は採用する。
10 倍の悪化なら用途によっては考える。(パターンが複雑・多岐の場合) 正規表現は開発効率と保守性が 10 倍よいと思うので。
47デフォルトの名無しさん (ワッチョイ 0663-aD55)
2019/12/13(金) 22:59:26.50ID:x4Cvv/aS0 >>46
switchとdicの関連は44が説明してくれてる
最適化次第でいい感じにしてくれるはずだからどっちもたいさない感じになると思う
個人的には性能差が10倍だろうが1000倍だろうが許容できるケースなら可読性を取る
今どき文字→数値変換でc-'0'なんて書かずに大体int.Parse使うのと同じ
UIに入力された氏名のローマ字変換みたいな1ユーザー1回で済むような処理に速度なんて無意味
GB単位のログデータをいじるなら数倍の差でも考慮すべき
なんなら入力データの傾向に応じてチューニングしやすい単純処理のほうが更に高性能にしやすい
switchとdicの関連は44が説明してくれてる
最適化次第でいい感じにしてくれるはずだからどっちもたいさない感じになると思う
個人的には性能差が10倍だろうが1000倍だろうが許容できるケースなら可読性を取る
今どき文字→数値変換でc-'0'なんて書かずに大体int.Parse使うのと同じ
UIに入力された氏名のローマ字変換みたいな1ユーザー1回で済むような処理に速度なんて無意味
GB単位のログデータをいじるなら数倍の差でも考慮すべき
なんなら入力データの傾向に応じてチューニングしやすい単純処理のほうが更に高性能にしやすい
48デフォルトの名無しさん (ワッチョイ fb68-xO71)
2019/12/13(金) 23:21:38.26ID:Lnvxq+5t0 俺なら、ひらがな小文字の変換は、変換元「ちゃ」とか「ぱっ」のパターンを文字数降順で優先的に置き換えるかな。
配列で変換パターンを保持して、それにない文字パターンは先頭から徐々に削っていく。
それなら「ぱ」と「は゜」なんかも判りやすく対応できると思うよ。
配列で変換パターンを保持して、それにない文字パターンは先頭から徐々に削っていく。
それなら「ぱ」と「は゜」なんかも判りやすく対応できると思うよ。
49デフォルトの名無しさん (ワッチョイ e752-RobM)
2019/12/13(金) 23:36:31.48ID:M1n71JyZ0 >>44, 45, 47
みんな有益な考察をしてくれるのでありがたい。感謝。
今まで正規表現が際立って遅いと体感することなかったけど、利用目的を想定した評価をきちんとしたことなかったので一連の議論はとても参考になりました。
みんな有益な考察をしてくれるのでありがたい。感謝。
今まで正規表現が際立って遅いと体感することなかったけど、利用目的を想定した評価をきちんとしたことなかったので一連の議論はとても参考になりました。
50デフォルトの名無しさん (ワッチョイ a201-VrMI)
2019/12/13(金) 23:57:37.29ID:+9OE4qBy0 オリジナルの文字列を1文字ずらしでzipして
2文字ずつ取得するイテレータでやるのがいいかなとか思ってたが
多少非効率でも↓ここの実装みたいに繰り返し変換していく方が
条件分岐が少なくて読みやすいかも
https://tools.m-bsys.com/original_tooles/romaji.php
https://tools.m-bsys.com/js/romaji.js
function hebonG(s) {
s = s.replace(/ん([aiueoy])/g, "n$1");
s = s.replace(/ん/g, "n");
s = s.replace(/n([bpm])/g, "m$1");
…
var hebonGMap = {
"kuぁ": "kua", "kuぃ": "kui", "kuぇ": "kue", "kuぉ": "kuo",
…
}
…
s = s.replace(/っch/g, "tch");
s = s.replace(/っ([kstnhmyrwgzdbp])/g, "$1$1");
2文字ずつ取得するイテレータでやるのがいいかなとか思ってたが
多少非効率でも↓ここの実装みたいに繰り返し変換していく方が
条件分岐が少なくて読みやすいかも
https://tools.m-bsys.com/original_tooles/romaji.php
https://tools.m-bsys.com/js/romaji.js
function hebonG(s) {
s = s.replace(/ん([aiueoy])/g, "n$1");
s = s.replace(/ん/g, "n");
s = s.replace(/n([bpm])/g, "m$1");
…
var hebonGMap = {
"kuぁ": "kua", "kuぃ": "kui", "kuぇ": "kue", "kuぉ": "kuo",
…
}
…
s = s.replace(/っch/g, "tch");
s = s.replace(/っ([kstnhmyrwgzdbp])/g, "$1$1");
51デフォルトの名無しさん (ワッチョイ e22c-3siJ)
2019/12/14(土) 11:11:39.02ID:8NRAnTxB052デフォルトの名無しさん (ワッチョイ e22c-3siJ)
2019/12/14(土) 11:24:37.56ID:8NRAnTxB053デフォルトの名無しさん (ワッチョイ e752-RobM)
2019/12/14(土) 16:02:25.78ID:BZ704rid0 >>51
まあね。ただ、C# の Match Evaluator 付き Regex.Replace は事前コンパイルできないと思う。
ちなみにあの後何度か測り直したのだが、switch より事前コンパイルなし正規表現は 2 倍遅かった。同等ではなかった、すまん。
45 によると Dictionary & ユーザー定義文字列操作は正規表現より 3-4 倍良かったそうだから、今回のケースでは Dictionary : switch : 事前コンパイルなし正規表現 = 3-4 : 2 : 1 くらいの性能比かと考えられる。
switch はカスケードがさらに増えると内部で Dictionary 化して最適化されるから、一般論としては 正規表現は事前コンパイルすれば switch に肉薄する、あるいは、多少超えるかもしれないが switch に Dictionary 最適化がかかったらまた離されるかもって感じではないかと。
>>52
ありがとう。Match Evaluator 正規表現でハッシュ置換するのはもう四半世紀も使っているテクだけど他で見たことなかったから、Ruby の例は参考になる。
まあね。ただ、C# の Match Evaluator 付き Regex.Replace は事前コンパイルできないと思う。
ちなみにあの後何度か測り直したのだが、switch より事前コンパイルなし正規表現は 2 倍遅かった。同等ではなかった、すまん。
45 によると Dictionary & ユーザー定義文字列操作は正規表現より 3-4 倍良かったそうだから、今回のケースでは Dictionary : switch : 事前コンパイルなし正規表現 = 3-4 : 2 : 1 くらいの性能比かと考えられる。
switch はカスケードがさらに増えると内部で Dictionary 化して最適化されるから、一般論としては 正規表現は事前コンパイルすれば switch に肉薄する、あるいは、多少超えるかもしれないが switch に Dictionary 最適化がかかったらまた離されるかもって感じではないかと。
>>52
ありがとう。Match Evaluator 正規表現でハッシュ置換するのはもう四半世紀も使っているテクだけど他で見たことなかったから、Ruby の例は参考になる。
54デフォルトの名無しさん (アウアウイー Sa1f-f14Z)
2019/12/15(日) 00:27:58.57ID:x+hGNtUDa このスレにいる人たちで
C#を日本語で記述ってのを実際にやってる人、どれくらいいるかな
https://togetter.com/li/1441951 を読んで試してみてもいいかなと思ったんだけど
VisualStudioのコード補完が利く環境ならIME切替の手間もさほどかからない気もするし
何か致命的なデメリットとかあるんだろうか
C#を日本語で記述ってのを実際にやってる人、どれくらいいるかな
https://togetter.com/li/1441951 を読んで試してみてもいいかなと思ったんだけど
VisualStudioのコード補完が利く環境ならIME切替の手間もさほどかからない気もするし
何か致命的なデメリットとかあるんだろうか
55デフォルトの名無しさん (アウアウウー Sa3b-xnB/)
2019/12/15(日) 02:49:23.51ID:SZPXyEbKa >>54
ほとんどいないのでは?w
デメリットはインテリセンスとの相性の悪さに尽きるね。
どうでもいいけど「C#を日本語で記述」の是非というより識別子に日本語を使うことの是非だよね
論より証拠、やってみたらいかに非合理な試みか分かると思うよ
ほとんどいないのでは?w
デメリットはインテリセンスとの相性の悪さに尽きるね。
どうでもいいけど「C#を日本語で記述」の是非というより識別子に日本語を使うことの是非だよね
論より証拠、やってみたらいかに非合理な試みか分かると思うよ
56デフォルトの名無しさん (ワッチョイ e22c-3siJ)
2019/12/15(日) 05:39:16.51ID:fpSJINfx0 Ruby では、RSpec(BDD)のユニットテストで、
日本語の関数名を付ける人はいるけど
まあ、テストだからね
日本語の関数名を付ける人はいるけど
まあ、テストだからね
57デフォルトの名無しさん (ワッチョイ 62ad-zBV4)
2019/12/15(日) 05:45:38.27ID:cmnyuAvp0 テストのメソッド名とかなら使っちゃうかな
58デフォルトの名無しさん (ワッチョイ e242-xO71)
2019/12/15(日) 06:17:17.09ID:6XATZvNs0 enumの要素で使うと便利
どうせ数はないからインテリセンスも問題なし
どうせ数はないからインテリセンスも問題なし
59デフォルトの名無しさん (ワッチョイ 5f01-xO71)
2019/12/15(日) 13:41:49.81ID:TLgol4W/060デフォルトの名無しさん (ワッチョイ a201-VrMI)
2019/12/15(日) 14:56:15.21ID:pFDibfNW0 補完はomnisharp + migemoで解決できる
他言語で変数名に日本語使うのはよくやってるけど扱う対象の用語が固まってる場合は便利
そうじゃない場合は結構厳格に命名ルールを決めないと逆にわかりにくくなったりする
他言語で変数名に日本語使うのはよくやってるけど扱う対象の用語が固まってる場合は便利
そうじゃない場合は結構厳格に命名ルールを決めないと逆にわかりにくくなったりする
61デフォルトの名無しさん (ワッチョイ 972d-3OBQ)
2019/12/15(日) 16:18:24.21ID:QBANyAHK0 俺が英語ができなかったり、デザインパターンの理解が足りなかったりするせいだとは思うけどさ
どうしてもファイル名=ネームスペース名=クラス名=主なメソッド名になりがちなんだわ
単一責任の原則に合わせた時、ファイル名〜メソッド名まで決める簡単な基準とかあったら教えて欲しいな
どうしてもファイル名=ネームスペース名=クラス名=主なメソッド名になりがちなんだわ
単一責任の原則に合わせた時、ファイル名〜メソッド名まで決める簡単な基準とかあったら教えて欲しいな
62デフォルトの名無しさん (ワイーワ2 FFfa-EbeN)
2019/12/15(日) 16:21:28.32ID:NIombkpjF Javaやりすぎると後遺症でそうなることがあるな
63デフォルトの名無しさん (ワッチョイ a201-VrMI)
2019/12/15(日) 16:49:35.38ID:pFDibfNW0 ファイル名=publicクラス名.csは一般的
ネームスペース名はそのクラスが属するレイヤーとかコンポーネントの名前
アーキテクチャが整理されてればあんまり迷わないと思う
クラス名=主なメソッド名は状況による
FormatterクラスにFormatメソッドがあるのは自然
Utilitiies > Formatter > Format
ネームスペース名はそのクラスが属するレイヤーとかコンポーネントの名前
アーキテクチャが整理されてればあんまり迷わないと思う
クラス名=主なメソッド名は状況による
FormatterクラスにFormatメソッドがあるのは自然
Utilitiies > Formatter > Format
64デフォルトの名無しさん (スッップ Sd02-PR0H)
2019/12/15(日) 17:58:43.69ID:LwtoOKkQd 日本語を使った感想
メリット
名称に悩まない(重要)
比較的読みやすい
デメリット
インテリセンスと相性が悪い
imeの切り替えが面倒
大文字小文字がないから名称が被りやすい
システムハンガリアン推奨
他にも何かあった気がする
メリット
名称に悩まない(重要)
比較的読みやすい
デメリット
インテリセンスと相性が悪い
imeの切り替えが面倒
大文字小文字がないから名称が被りやすい
システムハンガリアン推奨
他にも何かあった気がする
65デフォルトの名無しさん (アウアウウー Sa3b-xnB/)
2019/12/15(日) 18:23:34.11ID:yHa/r3w4a プロパティーやフィールドはいいけど、メソッドやイベントの名前は馬鹿っぽくはなるねw
66デフォルトの名無しさん (ワッチョイ 622c-b+2D)
2019/12/15(日) 18:24:56.51ID:ltDbPg3S0 プロパティはいいとしてメソッドは動詞(+名詞)の形にするの
日本語だと不自然だけどどうしてるのかな
日本語だと不自然だけどどうしてるのかな
67デフォルトの名無しさん (ワッチョイ 62ad-zBV4)
2019/12/15(日) 18:30:01.27ID:cmnyuAvp0 >>58
中点使ってるせいでC#6.0対応時にエラー吐いたプロジェクトあったわ
中点使ってるせいでC#6.0対応時にエラー吐いたプロジェクトあったわ
68デフォルトの名無しさん (アウアウカー Sac7-+v21)
2019/12/15(日) 18:49:58.62ID:yNhbn0Xna >>54
DBテーブル名/カラム名が日本語名のWindows業務システムで、
Entityクラスや画面コントロールの命名をDBそのまんまの日本語にしたら
ソースが滅茶苦茶読みやすくとても良い感じになった
以後、積極的に日本語で命名するようにしてる
自分の書き方だと、
日本語を使うのは画面項目や業務用語の名詞のみ、動詞は英語
英語とチャンポンして Update利用情報()、Is有効期限内 みたいなメソッド/ブロパティをよく作る
ローカル変数はiとかsとかtとか適当なプレフィクスをつけて無理やりcamelにする
フィールドは_始まり
とかかな
日本語で書くコメントが大幅に減らせてメリット大だと思う
デメリットは…C#関係ないけど
postgresだとテーブル名が日本語だとテーブルエクスポートが出来なくて不便、
多分ASP.NETみたいなWebシステムだと日本語名を使うのはリスク高い、
とか
DBテーブル名/カラム名が日本語名のWindows業務システムで、
Entityクラスや画面コントロールの命名をDBそのまんまの日本語にしたら
ソースが滅茶苦茶読みやすくとても良い感じになった
以後、積極的に日本語で命名するようにしてる
自分の書き方だと、
日本語を使うのは画面項目や業務用語の名詞のみ、動詞は英語
英語とチャンポンして Update利用情報()、Is有効期限内 みたいなメソッド/ブロパティをよく作る
ローカル変数はiとかsとかtとか適当なプレフィクスをつけて無理やりcamelにする
フィールドは_始まり
とかかな
日本語で書くコメントが大幅に減らせてメリット大だと思う
デメリットは…C#関係ないけど
postgresだとテーブル名が日本語だとテーブルエクスポートが出来なくて不便、
多分ASP.NETみたいなWebシステムだと日本語名を使うのはリスク高い、
とか
69デフォルトの名無しさん (アウアウエー Sa3a-aL8g)
2019/12/15(日) 20:10:28.99ID:KTmzWILYa 訳のわからん不具合踏みそう
日本語使ってると
日本語使ってると
70デフォルトの名無しさん (ワッチョイ 1b84-uKDx)
2019/12/15(日) 21:16:07.17ID:eTsOryw+0 Listについて質問なのですが
BindingList<T>にはToList()では代入できないのでしょうか?
LINQの結果をToListで代入しようと思ってたのですが
型が違うとか出るんです(自作クラスによるListです)
普通のList<T>へならできるのでBindingList固有の問題かと思います
仕方なくforeachで一つずつ代入して一応目的は達成してるんですが
LINQでforeach使わず抽出しておきながら
最後に代入でforeach使うのはバカらしいなあ・・・と思いまして
どうすれば直接LINQの結果をBindingListに入れられるのでしょう?
BindingList<T>にはToList()では代入できないのでしょうか?
LINQの結果をToListで代入しようと思ってたのですが
型が違うとか出るんです(自作クラスによるListです)
普通のList<T>へならできるのでBindingList固有の問題かと思います
仕方なくforeachで一つずつ代入して一応目的は達成してるんですが
LINQでforeach使わず抽出しておきながら
最後に代入でforeach使うのはバカらしいなあ・・・と思いまして
どうすれば直接LINQの結果をBindingListに入れられるのでしょう?
71デフォルトの名無しさん (ワッチョイ 622c-b+2D)
2019/12/15(日) 21:26:38.59ID:ltDbPg3S0 new BindingList<Hoge>(fuga.ToList())
72デフォルトの名無しさん (ワッチョイ 1b84-DoXq)
2019/12/15(日) 22:05:28.60ID:eTsOryw+073デフォルトの名無しさん (ワッチョイ 57da-boqi)
2019/12/16(月) 05:42:00.98ID:cXUrIyKd0 razor page のコーディングについてなんですが、
1ページのデータ量が多くなれば必然的にソースも長くなりますが、2000行とかになるとごちゃっとして「目に優しくない」ソースになっちゃいます。
目に優しいコーディング方法やら規約やら法則があれば教えてください。
1ページのデータ量が多くなれば必然的にソースも長くなりますが、2000行とかになるとごちゃっとして「目に優しくない」ソースになっちゃいます。
目に優しいコーディング方法やら規約やら法則があれば教えてください。
74デフォルトの名無しさん (ワッチョイ efa7-SgqX)
2019/12/16(月) 07:41:26.07ID:v/vzDWBs0 >>73
1メソッド300行以内っていう社内ローカルルール
1メソッド300行以内っていう社内ローカルルール
75デフォルトの名無しさん (ワッチョイ a201-VrMI)
2019/12/16(月) 15:28:44.50ID:+KWK+mzK076デフォルトの名無しさん (ワッチョイ c788-aD55)
2019/12/16(月) 17:57:20.50ID:I8DdFnIZ0 200も300も大差無いような…
77デフォルトの名無しさん (ワッチョイ 6bb2-5cGf)
2019/12/16(月) 20:05:28.74ID:FR/i0CTk0 やっと会社の環境がvisualstudio2010から2019になったわ、これで非同期無双できるw
78デフォルトの名無しさん (ドコグロ MM07-oPxD)
2019/12/16(月) 20:08:09.24ID:X2KrPzv7M そんな環境で2019なんか入れて大丈夫か?
アップデートで不具合引いてダウングレードさせられないように、不用意なアップデートはやめとけよ
アップデートで不具合引いてダウングレードさせられないように、不用意なアップデートはやめとけよ
79デフォルトの名無しさん (スップ Sd22-zBV4)
2019/12/16(月) 20:09:20.42ID:J5g2Edewd 2010とかサポート切れ直前やな
80デフォルトの名無しさん (アウアウイー Sa1f-f14Z)
2019/12/16(月) 21:08:24.24ID:LIM2IbDka 2010だとNuGetすら使えないんじゃ
54だけどレスありがとう>ALL
実践してる人もそこそこいるのね
テーブルやカラムを日本語で命名できるのってAccessに限らないのか・・・・
不具合の事例も知りたいけど、具体的に出てきたのは>>67くらい?
C#に閉じた範囲で使うぶんには大丈夫そうかな・・・・今度試してみるよ
54だけどレスありがとう>ALL
実践してる人もそこそこいるのね
テーブルやカラムを日本語で命名できるのってAccessに限らないのか・・・・
不具合の事例も知りたいけど、具体的に出てきたのは>>67くらい?
C#に閉じた範囲で使うぶんには大丈夫そうかな・・・・今度試してみるよ
81デフォルトの名無しさん (ワッチョイ a201-VrMI)
2019/12/16(月) 21:33:12.54ID:+KWK+mzK0 >>76
viewの行数とメソッドの行数の違い
viewの行数とメソッドの行数の違い
82デフォルトの名無しさん (ワッチョイ 5f01-rutQ)
2019/12/17(火) 09:59:27.04ID:GVP8bqm50 >>80
全角ピリオドとか&とかヤバそうに思えるのは使わないのが無難
date前月末とか昔から使ってます
昔々のACCESSで一部の通常全角文字が使えないとかありましたが、今はもう大丈夫と思ってます
将来的にトラブル可能性はゼロではないとしても、可読性のメリットのほうが遥かに大きい
例えば「要介護認定等基準時間」みたいなのを英字変数にするとかアホにもほどがある
全角ピリオドとか&とかヤバそうに思えるのは使わないのが無難
date前月末とか昔から使ってます
昔々のACCESSで一部の通常全角文字が使えないとかありましたが、今はもう大丈夫と思ってます
将来的にトラブル可能性はゼロではないとしても、可読性のメリットのほうが遥かに大きい
例えば「要介護認定等基準時間」みたいなのを英字変数にするとかアホにもほどがある
83ダーク王鍬大使 ◆SoVpkB15jY (ワッチョイ 9702-X5Um)
2019/12/17(火) 18:03:06.99ID:9VuoOKjt0 質問でふ(^^
Unityのアセットとか覗いたりするとifは使われてまふよね(^^
Switchが使われているの見たことないんでふが(^^
あれって使っちゃいけないとかってあるんでふか?(^^
ボッキング!(^^
Unityのアセットとか覗いたりするとifは使われてまふよね(^^
Switchが使われているの見たことないんでふが(^^
あれって使っちゃいけないとかってあるんでふか?(^^
ボッキング!(^^
84デフォルトの名無しさん (ワッチョイ a324-xO71)
2019/12/17(火) 18:30:01.62ID:I793zFiP0 最適化すると数行のswitch文はifに自動変換されるんじゃなかったっけ
85ダーク王鍬大使 ◆SoVpkB15jY (ワッチョイ 9702-X5Um)
2019/12/17(火) 18:39:07.95ID:9VuoOKjt0 そうだったんでふか(^^
教えていただき感謝感謝のボッキング!(^^
教えていただき感謝感謝のボッキング!(^^
86デフォルトの名無しさん (スッップ Sd02-IB+3)
2019/12/17(火) 19:40:18.25ID:vR4SZ06Rd class Hoge{
int Id
ICollection<Hoge> Hoges
}
ってクラスをEntityFramework使ってテーブルにしたんだけど無理だったりする?
Hogeテーブル(Id)と、Gehoテーブル(id、HogeId、HogeId2)後ろ二つ外部キーみたいなイメージなんだけどこういうパターンが調べても出てこない
int Id
ICollection<Hoge> Hoges
}
ってクラスをEntityFramework使ってテーブルにしたんだけど無理だったりする?
Hogeテーブル(Id)と、Gehoテーブル(id、HogeId、HogeId2)後ろ二つ外部キーみたいなイメージなんだけどこういうパターンが調べても出てこない
87デフォルトの名無しさん (スプッッ Sd22-IB+3)
2019/12/18(水) 15:34:43.72ID:bmnVQ6Qnd >>86
この構成じゃ出来ないことが分かったので質問を取り下げます
この構成じゃ出来ないことが分かったので質問を取り下げます
88デフォルトの名無しさん (オイコラミネオ MMab-7F0B)
2019/12/19(木) 01:57:08.71ID:Ty/KdhcjM webview使ってブラウザ操作してるんですけど、相手がASP使ったサイトだとボタン押したりテキストボックスに文字入れたりって操作は無理ですかね?
89デフォルトの名無しさん (ワッチョイ 17da-UiIE)
2019/12/19(木) 12:09:36.23ID:WCM9NoNV0 jsonファイルを読んで、木構造を編集して、jsonファイルに出力する
ファイルの入出力はJson.NETを使用
この場合内部のデータ構造はどう持つのがいいでしょうか?
Json.NETのJTokenを使うか、自作するか考えてますが、
標準的な手法は有りますか?
ファイルの入出力はJson.NETを使用
この場合内部のデータ構造はどう持つのがいいでしょうか?
Json.NETのJTokenを使うか、自作するか考えてますが、
標準的な手法は有りますか?
90デフォルトの名無しさん (ドコグロ MMdf-On3P)
2019/12/19(木) 12:13:14.10ID:+iaW+uMUM ちゃんと型を付けてデシリアライズ→加工→シリアライズする
型を付けるまでもないアドホックな処理ならそもそもC#なんか使わずに他のスクリプト言語を使う
型を付けるまでもないアドホックな処理ならそもそもC#なんか使わずに他のスクリプト言語を使う
91デフォルトの名無しさん (ワッチョイ d75f-r9Jq)
2019/12/19(木) 18:39:36.79ID:IsJpyVgV0 質問なのですが
エンティクラスを配列に入れて使うようなことはできないでしょうか?
数が多いのでループでコードをすっきりさせたいです。
こんな感じなのを
public class test()
{
using (var context = new MyContext(connection))
{
var datalist1 = context.MyEntities1.ToList();
〜
var datalist100 = context.MyEntities100.ToList();
}
//以下 共通処理
}
こんな感じで使いたい
string[] MyEntitiesList = new string[100];
MyEntitiesList[0] = "MyEntities1";
MyEntitiesList[1] = "MyEntities2";
〜
MyEntitiesList[99] = "MyEntities100";
for(var i =0;i<100;i++)
{
var datalist1 = context.MyEntitiesList[i].ToList();
}
エンティクラスを配列に入れて使うようなことはできないでしょうか?
数が多いのでループでコードをすっきりさせたいです。
こんな感じなのを
public class test()
{
using (var context = new MyContext(connection))
{
var datalist1 = context.MyEntities1.ToList();
〜
var datalist100 = context.MyEntities100.ToList();
}
//以下 共通処理
}
こんな感じで使いたい
string[] MyEntitiesList = new string[100];
MyEntitiesList[0] = "MyEntities1";
MyEntitiesList[1] = "MyEntities2";
〜
MyEntitiesList[99] = "MyEntities100";
for(var i =0;i<100;i++)
{
var datalist1 = context.MyEntitiesList[i].ToList();
}
92デフォルトの名無しさん (エムゾネ FFbf-hPjh)
2019/12/19(木) 19:11:55.40ID:aq+5Nz0cF var datalist1 =
上書きで良いなら最後のだけ入れろ
上書きで良いなら最後のだけ入れろ
93デフォルトの名無しさん (ワッチョイ d75f-r9Jq)
2019/12/19(木) 19:54:28.09ID:IsJpyVgV0 >>92
すまないよくわからないのでもう少し説明をお願いしたい
>>91
こんな感じで使いたいを修正してみました。
string[] MyList = new string[100];
MyList[0] = "MyEntities1";
MyList[1] = "MyEntities2";
〜
MyList[99] = "MyEntities100";
public class test(int i)
{
for(var i =0;i<100;i++)
{
using (var context = new MyContext(connection))
{
var datalist1 = context.MyList[i].ToList();
//以下 共通処理
}
}
}
すまないよくわからないのでもう少し説明をお願いしたい
>>91
こんな感じで使いたいを修正してみました。
string[] MyList = new string[100];
MyList[0] = "MyEntities1";
MyList[1] = "MyEntities2";
〜
MyList[99] = "MyEntities100";
public class test(int i)
{
for(var i =0;i<100;i++)
{
using (var context = new MyContext(connection))
{
var datalist1 = context.MyList[i].ToList();
//以下 共通処理
}
}
}
94デフォルトの名無しさん (ブーイモ MMdb-R6SS)
2019/12/19(木) 20:10:40.73ID:AGyCFxKvM >>93
92 は for ブロック内部の代入式の左辺が変わってないよ、というツッコミ。
やりたいことは、抽出対象プロパティをテキストで指定してシステマティックにデータ抽出したいってことでしょ?
Dictionary やインデクサで、テキスト => 対象プロパティ or 抽出メソッド、のマップを作って、Reflection か何かで呼び出せばできそうな気がするけど、LINQ to Entities でワークするかどうかは試してみないとわからないな。
92 は for ブロック内部の代入式の左辺が変わってないよ、というツッコミ。
やりたいことは、抽出対象プロパティをテキストで指定してシステマティックにデータ抽出したいってことでしょ?
Dictionary やインデクサで、テキスト => 対象プロパティ or 抽出メソッド、のマップを作って、Reflection か何かで呼び出せばできそうな気がするけど、LINQ to Entities でワークするかどうかは試してみないとわからないな。
95デフォルトの名無しさん (ワッチョイ 1752-R6SS)
2019/12/19(木) 20:25:17.21ID:qKbwpXVq0 >>93
有益な回答を得るためにもう少し説明が必要かも。
なぜ抽出対象プロパティをテキストで指定する必要があるの?
1 カラムごとに 100 回抽出しようとしているけど、まとめて 100 カラムをワンショットで抽出してから加工するのではなぜダメなの?
また環境が EF6 なのか EF Core なのかも言及した方がいいかもね。
有益な回答を得るためにもう少し説明が必要かも。
なぜ抽出対象プロパティをテキストで指定する必要があるの?
1 カラムごとに 100 回抽出しようとしているけど、まとめて 100 カラムをワンショットで抽出してから加工するのではなぜダメなの?
また環境が EF6 なのか EF Core なのかも言及した方がいいかもね。
96デフォルトの名無しさん (ワッチョイ 1752-R6SS)
2019/12/19(木) 20:38:12.29ID:qKbwpXVq0 ごめん、勘違いしていた。
テキストで指定したいのはカラムじゃなくてテーブルなんだね。
テキストで指定したいのはカラムじゃなくてテーブルなんだね。
97デフォルトの名無しさん (ワッチョイ d75f-r9Jq)
2019/12/19(木) 20:58:33.77ID:IsJpyVgV0 そうですそうです。
データを取り出すところ以外はほぼ変わらないのに
↑のコードだけでも1テーブルの数が多い場合余裕で1万行超えてしまうので
public bool test1()
{
}
public bool test2()
{
}
〜〜〜〜
public bool test1000()
{
}
と用意して
test1();
test2();
〜〜
test100();
を
public bool test()
{
}
for(var i =0;i<100;i++)
{
test( iLop );
}
だけにできないかと思っています。
データを取り出すところ以外はほぼ変わらないのに
↑のコードだけでも1テーブルの数が多い場合余裕で1万行超えてしまうので
public bool test1()
{
}
public bool test2()
{
}
〜〜〜〜
public bool test1000()
{
}
と用意して
test1();
test2();
〜〜
test100();
を
public bool test()
{
}
for(var i =0;i<100;i++)
{
test( iLop );
}
だけにできないかと思っています。
98デフォルトの名無しさん (ワッチョイ d75f-r9Jq)
2019/12/19(木) 21:00:56.21ID:IsJpyVgV0 >>95
環境はEF Core3.1 です。
環境はEF Core3.1 です。
99デフォルトの名無しさん (ワッチョイ 1752-R6SS)
2019/12/19(木) 21:11:26.20ID:qKbwpXVq0 抽出テーブルを動的に指定したいなら、DbSet<T> を返すプロパティが DbContext の派生クラスに定義されていると思います。
型引数 T にテキストは直接指定できないので、その DbSet<T> 型のプロパティをラップするメソッドを定義して、テキストを引数で渡してやればよいのではないでしょうか。こんな感じで。
class MyDbContext : DbContext {
DbSet<MyEntityDataModel1> MyEntity1 { get; set; }
DbSet<T> GetTable<T>(string table) where T : CommonBaseClassOfMyEntityDataModels =>
this.GetType().GetProperty(table) as IQueryable<T>;
}
// 呼び出し側
context.GetTable(“MyEntity1”).ToList();
型引数 T にテキストは直接指定できないので、その DbSet<T> 型のプロパティをラップするメソッドを定義して、テキストを引数で渡してやればよいのではないでしょうか。こんな感じで。
class MyDbContext : DbContext {
DbSet<MyEntityDataModel1> MyEntity1 { get; set; }
DbSet<T> GetTable<T>(string table) where T : CommonBaseClassOfMyEntityDataModels =>
this.GetType().GetProperty(table) as IQueryable<T>;
}
// 呼び出し側
context.GetTable(“MyEntity1”).ToList();
100デフォルトの名無しさん (ワッチョイ 1752-R6SS)
2019/12/19(木) 21:54:02.04ID:qKbwpXVq0 >>97
そういう目的ならテーブル名をテキストで指定する必要もなくて、
foreach (var prop in context.GetProperties())
{
var table = (prop as IQueryable<CommonBaseClass>).ToList();
// table に対するテスト処理
}
でよいかもしれない。
ただし下準備として、DbContext の全プロパティのデータコンテナを共通で受ける基底クラス CommonBaseClass を定義する必要がある。
似たようなことはやったことあるのだけど、このコードが手直しなく動くかどうかはわからない。
テスト処理もラムダ式のリストで用意しておいて、各テーブルと Zip() して適用するなど、LINQ を活用するとよいと思うよ。
そういう目的ならテーブル名をテキストで指定する必要もなくて、
foreach (var prop in context.GetProperties())
{
var table = (prop as IQueryable<CommonBaseClass>).ToList();
// table に対するテスト処理
}
でよいかもしれない。
ただし下準備として、DbContext の全プロパティのデータコンテナを共通で受ける基底クラス CommonBaseClass を定義する必要がある。
似たようなことはやったことあるのだけど、このコードが手直しなく動くかどうかはわからない。
テスト処理もラムダ式のリストで用意しておいて、各テーブルと Zip() して適用するなど、LINQ を活用するとよいと思うよ。
101デフォルトの名無しさん (ワッチョイ 17da-UiIE)
2019/12/19(木) 21:59:04.37ID:WCM9NoNV0 >>90
説明が稚拙で申し訳ないです
プログラムはフォームで、木構造の編集とはノードのコピーや削除、値の編集などをGUIで行います
GUIの理由はJSONファイルはあるスマートウォッチのカスタムフェイス用で配置などを確認するためです
自分が知りたい事はc#でよく使われる木構造を扱うライブラリです
説明が稚拙で申し訳ないです
プログラムはフォームで、木構造の編集とはノードのコピーや削除、値の編集などをGUIで行います
GUIの理由はJSONファイルはあるスマートウォッチのカスタムフェイス用で配置などを確認するためです
自分が知りたい事はc#でよく使われる木構造を扱うライブラリです
102デフォルトの名無しさん (ワッチョイ d75f-r9Jq)
2019/12/19(木) 22:24:53.20ID:IsJpyVgV0103デフォルトの名無しさん (ワッチョイ d75f-r9Jq)
2019/12/19(木) 23:07:37.09ID:IsJpyVgV0104デフォルトの名無しさん (ワッチョイ 1752-R6SS)
2019/12/19(木) 23:56:40.46ID:qKbwpXVq0 プロパティ DbSet<EntityModel1> MyEntity1 や DbSet<EntityModel2> MyEntity2 の型引数 EntityModel1, EntityModel2 があるとすると、その共通基底クラス BaseEntityModel を定義する必要があります。
class EntityModel1 : BaseEntityModel {} というように。BaseEntityModel は抽象クラスでも可。
そうすると、.GetProperty() の返り値の型が、DbSet<EntityModel1> だったり DbSet<EntityModel2> だったりするのだけど、これが IQueryable<BaseEntityModel> という型で共通的に受けられるということを想定しています。
class EntityModel1 : BaseEntityModel {} というように。BaseEntityModel は抽象クラスでも可。
そうすると、.GetProperty() の返り値の型が、DbSet<EntityModel1> だったり DbSet<EntityModel2> だったりするのだけど、これが IQueryable<BaseEntityModel> という型で共通的に受けられるということを想定しています。
105デフォルトの名無しさん (ワッチョイ 1752-R6SS)
2019/12/19(木) 23:58:37.24ID:qKbwpXVq0 訂正。
.GetProperty() ではなく .GetProperties() でした。
.GetProperty() ではなく .GetProperties() でした。
106デフォルトの名無しさん (ワッチョイ d75f-r9Jq)
2019/12/20(金) 00:14:57.12ID:wMdfjBuG0107デフォルトの名無しさん (アウアウウー Sa5b-On3P)
2019/12/20(金) 02:04:01.33ID:aZ9V3LMHa >>101
よく分からん理屈だなあ
そのスマートウォッチの設定に限らず、世の中のアプリが扱うデータなんて大半は木構造なわけだが、
そいつらがみんな木構造を明示的に扱うようなGUIを持ってるか?
断言するが、明示的に木構造を扱うようなUIが必要なのはフォルダツリーのように再帰的な構造を扱う必要がある場合だけだ
それ以外は必ずもっと適したUIがある
よく分からん理屈だなあ
そのスマートウォッチの設定に限らず、世の中のアプリが扱うデータなんて大半は木構造なわけだが、
そいつらがみんな木構造を明示的に扱うようなGUIを持ってるか?
断言するが、明示的に木構造を扱うようなUIが必要なのはフォルダツリーのように再帰的な構造を扱う必要がある場合だけだ
それ以外は必ずもっと適したUIがある
108デフォルトの名無しさん (ワッチョイ 972d-vnDE)
2019/12/20(金) 02:21:20.80ID:oj5hMkFq0 while文がネストしていた時、階層の奥から一番外側のwhileループまでブレイクするにはどうするのが正しいのでしょうか?
while(true){ while(true){
if(true) 外側のwhileまでbreak;
}}
よろしくお願いします
while(true){ while(true){
if(true) 外側のwhileまでbreak;
}}
よろしくお願いします
109デフォルトの名無しさん (ワッチョイ b763-CWbB)
2019/12/20(金) 02:23:20.84ID:qHTdS2+z0 goto
110デフォルトの名無しさん (ワッチョイ 9fad-WY45)
2019/12/20(金) 03:01:50.54ID:1digpYZT0 ここでいいのか分からないんですが質問させて下さい。
macでのvisual studioないしはC#の解説の載っているサイト、もしくは操作方法などを教えてください。
つい先日3Dモデリングやゲーム開発に憧れてC#の本を手に取りました。情報系の知識はないに等しく、せいぜい中学の授業レベルです。
「やさしいC# 第3版」を手に進めようとしたのですが、当方macで作業しようとしていたため、本の内容と実際の動きが異なり、四苦八苦しています。
現状なんとかhello worldはできましたが手順が理解できておらず困惑しています。
よろしくお願いします。
macでのvisual studioないしはC#の解説の載っているサイト、もしくは操作方法などを教えてください。
つい先日3Dモデリングやゲーム開発に憧れてC#の本を手に取りました。情報系の知識はないに等しく、せいぜい中学の授業レベルです。
「やさしいC# 第3版」を手に進めようとしたのですが、当方macで作業しようとしていたため、本の内容と実際の動きが異なり、四苦八苦しています。
現状なんとかhello worldはできましたが手順が理解できておらず困惑しています。
よろしくお願いします。
111デフォルトの名無しさん (ワッチョイ 17da-UiIE)
2019/12/20(金) 05:17:47.97ID:GjFm0fld0 >>107
漏れてて申し訳ないです
そのスマートウォッチではノードの記述順によって表示順が決まるので木構造の順番を入れ替えたい
入れ替える枝の深さもまちまちですので木構造を直接編集できた方が良いと思った訳です
また、全てを木構造で扱うのではなく、末端部は類型化されてますのでクラスにして編集の予定です
漏れてて申し訳ないです
そのスマートウォッチではノードの記述順によって表示順が決まるので木構造の順番を入れ替えたい
入れ替える枝の深さもまちまちですので木構造を直接編集できた方が良いと思った訳です
また、全てを木構造で扱うのではなく、末端部は類型化されてますのでクラスにして編集の予定です
112デフォルトの名無しさん (ワッチョイ 1752-R6SS)
2019/12/20(金) 07:23:20.70ID:NMJ3uqPu0 >>106
当初は利用目的がわからなかったため、.GetProperties() やジェネリックで対象を動的に指定して DbSet<T> 型プロパティを呼び出す方法を提案しましたが、
DbContext に MyEntiyty1, MyEntity2, ... と 100 個のテーブルがあり、個々のテーブルに対応した Test1, Test2 ... というテスト関数を地の文で定義しており、
これをシステマティックに対応させたいというのが課題の本質であるなら、実はジェネリックとか使わなくてもできます。
テスト関数 Test1 は DbSet<MyEntityDataModel1> が入力で bool が出力として bool result1 = context.MyEntiti1.Test1() or Test1(context.MyEntity1)
と記述できるように定義されていると思いますが、これを下記のように変形すればよいと思います。
1. MyDbContext を入力として bool result1 = context.Test1() or Test1(context) と記述できるようにテスト関数を書き換える
(Test1 内部の冒頭で context.MyEntity1 と対象を指定する)
2. テスト関数をラムダ式にし、地の文で定義している Test1, Test2 ... というメソッド群をリストオブジェクトにする
List<Func<MyDbContext, bool>> TestList =
new [] { context => { context.MyEntity1 /* ... */ },
context => { context.MyEntity2 /* ... */ }, ... };
3. using ブロック内 for/foreach 文でリストオブジェクトをキックする
using (var context = new MyDbContext())
{
bool result[100];
for (var i = 0; i < 100; i++)
{
result[i] = TestList[i](context);
}
}
当初は利用目的がわからなかったため、.GetProperties() やジェネリックで対象を動的に指定して DbSet<T> 型プロパティを呼び出す方法を提案しましたが、
DbContext に MyEntiyty1, MyEntity2, ... と 100 個のテーブルがあり、個々のテーブルに対応した Test1, Test2 ... というテスト関数を地の文で定義しており、
これをシステマティックに対応させたいというのが課題の本質であるなら、実はジェネリックとか使わなくてもできます。
テスト関数 Test1 は DbSet<MyEntityDataModel1> が入力で bool が出力として bool result1 = context.MyEntiti1.Test1() or Test1(context.MyEntity1)
と記述できるように定義されていると思いますが、これを下記のように変形すればよいと思います。
1. MyDbContext を入力として bool result1 = context.Test1() or Test1(context) と記述できるようにテスト関数を書き換える
(Test1 内部の冒頭で context.MyEntity1 と対象を指定する)
2. テスト関数をラムダ式にし、地の文で定義している Test1, Test2 ... というメソッド群をリストオブジェクトにする
List<Func<MyDbContext, bool>> TestList =
new [] { context => { context.MyEntity1 /* ... */ },
context => { context.MyEntity2 /* ... */ }, ... };
3. using ブロック内 for/foreach 文でリストオブジェクトをキックする
using (var context = new MyDbContext())
{
bool result[100];
for (var i = 0; i < 100; i++)
{
result[i] = TestList[i](context);
}
}
113デフォルトの名無しさん (アウアウウー Sa5b-On3P)
2019/12/20(金) 08:59:06.48ID:aZ9V3LMHa114デフォルトの名無しさん (オイコラミネオ MMab-7F0B)
2019/12/20(金) 19:28:07.00ID:laM9bMPJM >>110
まずMACを捨てましょう
プログラミングはwindowsでないと、今は良くても後々面倒だと思います
私がゲーム開発してた頃はDirectX使ってました
3Dプログラミングはサインコサインタンジェント使いまくりなので数学の知識がいります
2Dは足し算引き算ぐらいなので初心者でもできると思います
画面にドット絵表示までが鬼門ですがそこ乗り越えられたら楽しい世界が待ってるのでがんばってください!
まずMACを捨てましょう
プログラミングはwindowsでないと、今は良くても後々面倒だと思います
私がゲーム開発してた頃はDirectX使ってました
3Dプログラミングはサインコサインタンジェント使いまくりなので数学の知識がいります
2Dは足し算引き算ぐらいなので初心者でもできると思います
画面にドット絵表示までが鬼門ですがそこ乗り越えられたら楽しい世界が待ってるのでがんばってください!
115デフォルトの名無しさん (スッップ Sdbf-hGMP)
2019/12/20(金) 20:00:27.38ID:FDXklgq8d >>114
MacでもWindowsが動かせるから捨てる必要なし
MacでもWindowsが動かせるから捨てる必要なし
116デフォルトの名無しさん (ワッチョイ d75f-r9Jq)
2019/12/20(金) 20:09:06.50ID:wMdfjBuG0■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 【おこめ】「有能だったんじゃ」おこめ券で批判殺到の鈴木農水大臣…ネットでは前任の“進次郎再評価” ★2 [ぐれ★]
- 「暖房が使えない」「食費が高くて子どもの栄養が…」 物価高に苦しむ子育て世帯、政府に期待する支援は ★2 [蚤の市★]
- オイルマッサージ施術中20代女性にわいせつ行為か セラピストの男(30)を再逮捕 余罪複数とみて警視庁が捜査 [どどん★]
- 内閣支持、微減59.9% 5割超が補正予算評価 時事通信世論調査 [どどん★]
- 【中国外務省】日本への渡航自粛を再度呼びかけ 今度は「地震発生」を理由に [ぐれ★]
- 日本語が話せない「外国籍」の子が急増中、授業がストップ、教室から脱走も…先生にも大きな負担「日本語支援」追いつかず★3 [七波羅探題★]
- ラーメンにカマボコ入れてる店、セコすぎだろ。いらねえから200円安くしろや!!ボケ!!! [782460143]
- Vtuber「人気アニメとコラボします!」←これでVが叩かれるの謎じゃね
- 愛国者「徴兵されるのは嫌。でも敵が侵略してきたら考えます」 [834922174]
- 高市内閣の支持率、下落wwwwwwwwwww [834922174]
- Xでフォローしてきた人をフォロバして相手のフォロー解除するのが趣味なんだが
- 【悲報】日中戦争5割が賛成、高市キッズたち徴兵へ [834922174]
