Datagrid: Number formatting

Posted on 2004-10-28
Medium Priority
Last Modified: 2012-06-21
Hi experts,
I have created a dynamic data table and added a following column to it.

        dtFiles.Columns.Add("Size", GetType(Long))

Now when I add the data to it I use the following line of code

newRow("Size") = FileLen(ofdlg.FileNames(i))


Problem: I am unable to fortamt the number, e.g., if the file size is 2322, I want it to appear like, 2,322

How do I achieve it, yet I do not want to change the datatype to string as it is does not perform well in sorting.

Thanks in adv.

Question by:msali
  • 2
LVL 19

Expert Comment

ID: 12431327
You need to Format the particular Column of the DataTable
Use DataGrid Table Style and TextBox Column Style to do it

        Dim ts1 As New DataGridTableStyle
        ts1.MappingName = "Table1" 'The Name of table in the DataTable

        Dim Col As New DataGridTextBoxColumn
        Col.MappingName = "Size" 'Name of Column in the Table
        Col.HeaderText = "Size"
        Col.Width = 100
        Col.Format = "N" 'Set the Format to Numeric
        ts1.GridColumnStyles.Add(Col) 'Add the Column Style to TableStyle

       DataGrid.TableStyles.Add(ts1) 'Add the Table Style to DataGrid


Author Comment

ID: 12432857
arif eqbal, i tried what you suggested, but it gives me an error that "Size" is already defined in my DataGridStyles.

So I uesed the RemoveAt method to remove the Size column from my grid style and then added it again but now it as added it at the end of my grid.

FYI: following is the code that I have written for mapping grid with cols and styles

        dsFiles = New DataSet("Files")
        grdFiles.ParentRowsVisible = False
        grdFiles.DataSource() = dsFiles
        grdFiles.DataMember = "Files"

        Dim grdStyle As New DataGridTableStyle
        grdStyle.MappingName = dsFiles.Tables("Files").TableName

LVL 19

Accepted Solution

arif_eqbal earned 500 total points
ID: 12434794
Just before the last line in your posted code add the following lines

  Dim Col As New DataGridTextBoxColumn
        Col.MappingName = "Size" 'Name of Column in the Table
        Col.HeaderText = "Size"
        Col.Width = 100
        Col.Format = "N" 'Set the Format to Numeric


Featured Post

2018 Annual Membership Survey

Here at Experts Exchange, we strive to give members the best experience. Help us improve the site by taking this survey today! (Bonus: Be entered to win a great tech prize for participating!)

Question has a verified solution.

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

This tutorial demonstrates one way to create an application that runs without any Forms but still has a GUI presence via an Icon in the System Tray. The magic lies in Inheriting from the ApplicationContext Class and passing that to Application.Ru…
It was really hard time for me to get the understanding of Delegates in C#. I went through many websites and articles but I found them very clumsy. After going through those sites, I noted down the points in a easy way so here I am sharing that unde…
SQL Database Recovery Software repairs the MDF & NDF Files, corrupted due to hardware related issues or software related errors. Provides preview of recovered database objects and allows saving in either MSSQL, CSV, HTML or XLS format. Ensures recov…
The video provides a quick and easy steps to migrate MBOX file to well known Outlook PST and Office 365. Besides this, it also supports and migrates more than 20 email clients of MBOX which include AppleMail, Opera, Thunderbird and SeaMonkey effortl…
Suggested Courses
Course of the Month3 days, 19 hours left to enroll

599 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