Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 104967
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T01:21:53+00:00 2026-05-11T01:21:53+00:00

How to make NameValueCollection accessible to LINQ query operator such as where, join, groupby?

  • 0

How to make NameValueCollection accessible to LINQ query operator such as where, join, groupby?

I tried the below:

private NameValueCollection RequestFields() {     NameValueCollection nvc = new NameValueCollection()                                   {                                       {'emailOption: blah Blah', 'true'},                                       {'emailOption: blah Blah2', 'false'},                                       {'nothing', 'false'},                                       {'nothinger', 'true'}                                   };     return nvc;  }  public void GetSelectedEmail() {     NameValueCollection nvc = RequestFields();     IQueryable queryable = nvc.AsQueryable(); } 

But I got an ArgumentException telling me that the source is not IEnumerable<>.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-11T01:21:54+00:00Added an answer on May 11, 2026 at 1:21 am

    You need to ‘lift’ the non-generic IEnumerable to an IEnumerable<string>. It has been suggested that you use OfType but that is a filtering method. What you’re doing is the equivalent of a cast, for which there is the Cast operator:

    var fields = RequestFields().Cast<string>(); 

    As Frans pointed out, this only provides access to the keys. You would still need to index into the collection for the values. Here is an extension method to extract KeyValuePairs from the NameValueCollection:

    public static IEnumerable<KeyValuePair<string, string>> ToPairs(this NameValueCollection collection) {     if(collection == null)     {         throw new ArgumentNullException('collection');     }      return collection.Cast<string>().Select(key => new KeyValuePair<string, string>(key, collection[key])); } 

    Edit: In response to @Ruben Bartelink’s request, here is how to access the full set of values for each key using ToLookup:

    public static ILookup<string, string> ToLookup(this NameValueCollection collection) {     if(collection == null)     {         throw new ArgumentNullException('collection');     }      var pairs =         from key in collection.Cast<String>()         from value in collection.GetValues(key)         select new { key, value };      return pairs.ToLookup(pair => pair.key, pair => pair.value); } 

    Alternatively, using C# 7.0 tuples:

    public static IEnumerable<(String name, String value)> ToTuples(this NameValueCollection collection) {     if(collection == null)     {         throw new ArgumentNullException('collection');     }      return         from key in collection.Cast<string>()         from value in collection.GetValues(key)         select (key, value); } 
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Make a new AS3 Document in Flash, paste in the following code and run
To make it short: hibernate doesn't support projections and query by example? I found
make is not only useful for building your programming project, but it seems to
To make things easier when switching between machines (my workstation at the office and
We make infrastructure services (data retrieval and storage) and small smart client applications (fancy
To make a JavaScript class with a public method I'd do something like: function
I make a lot of web applications and from time to time I need
To make click-able divs, I do: <div class=clickable url=http://google.com> blah blah </div> and then
I make a user control and then want to include it on a page
make -C /usr/src/linux-2.6.32.9 M=`pwd` LD /root/test/lkm/built-in.o Building modules, stage 2. MODPOST 1 modules make:

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.