Solved

Convert datareader to CSV and export to web browser in ASP.NET C#

Posted on 2007-11-22
10
1,967 Views
Last Modified: 2008-02-01
I have a datareader

while (thisReader.Read())
{
}

Now how can I export the contents of this datarader to a web browser in CSV format, so the user can save the file on this desktop.

0
Comment
Question by:mugsey
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 5
  • 4
10 Comments
 
LVL 39

Expert Comment

by:Pratima Pharande
ID: 20333725
Try this
 //Add Response header 
        Response.Clear();
        Response.AddHeader("content-disposition", string.Format("attachment;filename={0}.csv", fileName));
        Response.Charset = "";
        Response.ContentType = "application/vnd.xls";
        //GET Data From Database                
        SqlConnection cn = new SqlConnection(dataSrc.ConnectionString);
        string query = dataSrc.SelectCommand.Replace("\r\n", " ").Replace("\t", " ");
        
        SqlCommand cmd = new SqlCommand(query, cn);
        
        cmd.CommandTimeout = 999999 ;
        cmd.CommandType    = CommandType.Text;
        try
        {
            cn.Open();
            SqlDataReader dr = cmd.ExecuteReader();
            StringBuilder sb = new StringBuilder();            
            //Add Header          
            for (int count = 0; count < dr.FieldCount; count++)
            {
                if (dr.GetName(count) != null)
                    sb.Append(dr.GetName(count));
                if (count < dr.FieldCount - 1)
                {
                    sb.Append(",");
                }
            }
            Response.Write(sb.ToString() + "\n");
            Response.Flush();            
            //Append Data
            while (dr.Read())
            {
                sb = new StringBuilder();
               
                for (int col = 0; col < dr.FieldCount - 1; col++)
                {
                    if (!dr.IsDBNull(col))
                        sb.Append(dr.GetValue(col).ToString().Replace(",", " "));
                    sb.Append(",");
                }
                if (!dr.IsDBNull(dr.FieldCount - 1))
                    sb.Append(dr.GetValue(dr.FieldCount - 1).ToString().Replace(",", " "));
                Response.Write(sb.ToString() + "\n");
                Response.Flush();
            }
            dr.Dispose();

Open in new window

0
 
LVL 39

Expert Comment

by:Pratima Pharande
ID: 20333726
0
 
LVL 7

Expert Comment

by:bungHoc
ID: 20333738
Try this:

private string ToCSV(DataTable dataTable)
{
 
  DataTable schemaTable = myReader.GetSchemaTable();
 
  StringBuilder sb = new StringBuilder();      
  foreach (DataColumn column in schemaTable.Columns)
  {
    sb.Append(column.ColumnName + ',');
  }            
 
  sb.Append("\r\n");
      
  foreach (DataRow row in schemaTable.Rows)
  {
    foreach (DataColumn column in schemaTable.Columns)
    {
      sb.Append(row[column].ToString() + ',');
    }                  
    sb.Append("\r\n");
  }      
  return sb.ToString();
}

Open in new window

0
Salesforce Made Easy to Use

On-screen guidance at the moment of need enables you & your employees to focus on the core, you can now boost your adoption rates swiftly and simply with one easy tool.

 

Author Comment

by:mugsey
ID: 20333747
OK thanks guys I will try in the next hour
0
 

Author Comment

by:mugsey
ID: 20333769
Thanks pratima_mcs

How can I specify the file name and where to save the file?  Thanks
0
 
LVL 39

Expert Comment

by:Pratima Pharande
ID: 20333830
When you run this code it will ask with a popup to open , save
0
 

Author Comment

by:mugsey
ID: 20333949
OK thanks - so you know the line

Response.AddHeader("content-disposition", string.Format("attachment;filename={0}.csv", fileName));

Where does filename come from?

You see my code is like this

Currently I have a datareader that is populated from a dynamic search

  while (thisReader.Read())
                {
                 

                }

How can I amend your code above so it works



0
 
LVL 39

Expert Comment

by:Pratima Pharande
ID: 20333974
Response.AddHeader("content-disposition", string.Format("attachment;filename={0}.csv", fileName));

in this they have used the parament send to the function ...

you can use your own tempory file name there like

Response.AddHeader("content-disposition", string.Format("attachment;filename=temp.csv", fileName));

that will appear by default in save dialog
0
 

Author Comment

by:mugsey
ID: 20334019
OK thANKS

But could you amend your example so it wiould fit into the following?

while (thisReader.Read())
                {
                 

                }



0
 
LVL 39

Accepted Solution

by:
Pratima Pharande earned 500 total points
ID: 20337369

//Add Response header 
        Response.Clear();
        Response.AddHeader("content-disposition", string.Format("attachment;filename={0}.csv", fileName));
        Response.Charset = "";
        Response.ContentType = "application/vnd.xls";
       
                
            StringBuilder sb = new StringBuilder();            
            //Add Header   Put this if you want headers        
            for (int count = 0; count < thisReader.FieldCount; count++)
            {
                if (thisReader.GetName(count) != null)
                    sb.Append(thisReader.GetName(count));
                if (count < thisReader.FieldCount - 1)
                {
                    sb.Append(",");
                }
            }
            Response.Write(sb.ToString() + "\n");
            Response.Flush();            
            //Append Data
            while (thisReader.Read())
            {
                sb = new StringBuilder();
               
                for (int col = 0; col < thisReader.FieldCount - 1; col++)
                {
                    if (!thisReader.IsDBNull(col))
                        sb.Append(thisReader.GetValue(col).ToString().Replace(",", " "));
                    sb.Append(",");
                }
                if (!thisReader.IsDBNull(thisReader.FieldCount - 1))
                    sb.Append(thisReader.GetValue(thisReader.FieldCount - 1).ToString().Replace(",", " "));
                Response.Write(sb.ToString() + "\n");
                Response.Flush();
            }
            thisReader.Dispose();

Open in new window

0

Featured Post

Ready to get started with anonymous questions?

It's easy! Check out this step-by-step guide for asking an anonymous question on Experts Exchange.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

ASP.Net to Oracle Connectivity Recently I had to develop an ASP.NET application connecting to an Oracle database.As I am doing it first time ,I had to solve several problems. This article will help to such developers  to develop an ASP.NET client…
Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
Michael from AdRem Software outlines event notifications and Automatic Corrective Actions in network monitoring. Automatic Corrective Actions are scripts, which can automatically run upon discovery of a certain undesirable condition in your network.…
Do you want to know how to make a graph with Microsoft Access? First, create a query with the data for the chart. Then make a blank form and add a chart control. This video also shows how to change what data is displayed on the graph as well as form…

636 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question