Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


dataGridView - Egen sortering?

Postades av 2007-11-17 15:57:40 - Kristian Gerardsson, i forum c# (c-sharp), Tråden har 1 Kommentarer och lästs av 1133 personer

Vill kunna sortera en av kolumnerna på mitt eget sätt, vet inte ens om det går, men jag tror det :)

Värde som finns i kolumnen är numeriska
Kan vara allt från 0,001 till 500,000
(engelsk variant, där kommatecken är tusen-avdelare)
förutom nummer kan värdet "N/A" finnas med

Just nu är kolumnen satt till Sortable: Automatic
och som vanligtvis tolkas värdena som en sträng där tex 200 soteras efter talet 154000
jag vill såklart ha dem i storleksordning

Hur ska jag göra?


Svara

Sv: dataGridView - Egen sortering?

Postades av 2008-10-03 21:39:39 - Torgrim Brochmann

Hej,

Beroende på om du har knutit din grid till en datakälla eller inte, så finns det två sätt. Utgår från att du inte har gjort det här. I så fall så använder du dig av Sort-metoden med en klass som implementerar IComparer, typ så här:

private class MinKomparator : System.Collections.IComparer
{

SortOrder _order;
public MinKomparator(SortOrder order)
{
_order = order;
}
#region Implementation av IComparer

public int Compare(object x, object y)
{
int CompareValue = 0;

DataGridViewRow rad1 = (DataGridViewRow)x;
DataGridViewRow rad2 = (DataGridViewRow)y;

if (rad1.Cells[0].Value != "N/A" &&
rad2.Cells[0].Value != "N/A")
{
// Vi har nu ett tal
double rad1_varde = (double)rad1.Cells[0].Value;
double rad2_varde = (double)rad2.Cells[0].Value;

if (rad1_varde == rad2_varde)
{
CompareValue = 0;
}
else if (rad1_varde > rad2_varde)
{
CompareValue = 1;
}
else
{
CompareValue = -1;
}

}

// Kolla vilken ordning vi skall sortera i
if (_order == SortOrder.Descending) CompareValue *= -1;

return CompareValue;
}

#endregion
}

Denna lägger du sedan till i din klass där du har din datagrid, och sen anropar du den med

minDataGrid.Sort(new MinKomparator(ord));

Om du har knutit din datagrid till någon sorts data, så måste du sortera dina data i stället för att använda datagriddens sorteringsfunktion.

// Torgrim


Svara

Nyligen

  • 19:55 kick-off med fokus på hälsa?
  • 19:53 kick-off med fokus på hälsa?
  • 16:24 Föreslå en skönhetsklinik online
  • 16:23 Föreslå en skönhetsklinik online
  • 18:42 Hvor finder man håndlavede lamper
  • 18:41 Hvor finder man håndlavede lamper
  • 16:36 Allt du behöver veta om keramiskt
  • 16:14 Vem anlitar man egentligen när tak

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 570 707
27 958
271 751
826
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies