質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VB

VB(ビジュアルベーシック)はマイクロソフトによってつくられたオブジェクト指向プログラミング言語のひとつで、同社のQuickBASICが拡張されたものです。VB6の進化版といわれています。

VB.NET

Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。

Q&A

解決済

1回答

2675閲覧

VB.netのLinqを使った検索での条件指定

trainy

総合スコア8

VB

VB(ビジュアルベーシック)はマイクロソフトによってつくられたオブジェクト指向プログラミング言語のひとつで、同社のQuickBASICが拡張されたものです。VB6の進化版といわれています。

VB.NET

Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。

0グッド

0クリップ

投稿2017/03/30 08:57

###前提・実現したいこと
CSVのデータをLinqの機能を利用して読み込みたいです。
その際にWhere句に条件を指定したいのですが、複数条件をつける方法が分かりません。
やりたいのはある列にコードが入力されていて、そのコードで検索をかけたいです。
ただしコードには先頭に*が入っている場合があり、がCSVのデータに入っていた場合はを省いた値で完全一致させたいです。

###発生している問題・エラーメッセージ

試行錯誤して作成したのですが、下記ソースだと後方一致で検索されてしまいます。

###該当のソースコード
Dim lineVals = From lines In inputFile
Where BaseUtil.RightLen(lines(whereColIndex), Target.Length).Contains(Target)
Order By lines(2), lines(18), lines(5), lines(4)
Select lines

※Targetに検索したいコードが入ってきます。
※lines(whereColIndex)が検索したいCSVの列の値です。
※RightLenは文字列の右何文字かを取得する自前の関数です。
※検索は※が入っていないコードで検索するので、TargetのLengthで取れると思ったのですが、上記のとおり後方一致となってしまいました。

###試したこと
Where句でif文がかけて、lines(whereColIndex)の最初の1文字が※だったらとか判断できればと思ったのですが、、、。

###補足情報(言語/FW/ツール等のバージョンなど)
.netFramework4.0 Windows10

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

すいません、自己解決しました。

単純にWhere句のところを下記のとおり変更しました。

Where lines(divideColIndex).Equals(Target) OrElse lines(divideColIndex).Equals("*" + Target)

投稿2017/03/30 09:46

trainy

総合スコア8

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問