vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Mails senden, abrufen und decodieren - ganz easy ;-)  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB.NET - Ein- und Umsteiger
Table.compute - String zuvor in Double umwandeln 
Autor: Bingopark
Datum: 16.01.10 14:51

Hallo allerseits,

um den Mittelwert in einer Spalte meiner Tabelle zu berechnen nutze ich folgenden Code, der eigentlich gut funktioniert...

MeinMittelwert = MeineTabelle.Compute("Avg(MeineSpalte)", "")
...solange die Spalte "MeineSpalte" keine String-Werte enthält. Wie kann ich in dem oben stehenden Ausdruck erreichen, dass Stringwerte zuvor in Double konvertiert werden?
Dieses ist leider notwendig, da ich die Tabellen importiere und die Daten dort als String vorliegen.

Danke!
Bingopark

----
Meine Komponenten sind:
Visual Studio 2008 (Standard) SP 1
Windows 7 SP 1

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Table.compute - String zuvor in Double umwandeln 
Autor: keco
Datum: 16.01.10 15:08

Double.Parse(...)
Double.TryParse(...)
CDbl(...)
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Table.compute - String zuvor in Double umwandeln 
Autor: ModeratorDaveS (Moderator)
Datum: 16.01.10 16:58

Und wie "importierst" du die Daten?

________
Alle Angaben ohne Gewähr. Keine Haftung für Vorschläge, Tipps oder sonstige Hilfe, falls es schiefgeht, nur Zeit verschwendet oder man sonst nicht zufrieden ist

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Table.compute - String zuvor in Double umwandeln 
Autor: Bingopark
Datum: 17.01.10 01:46

per xml.

Bingopark

----
Meine Komponenten sind:
Visual Studio 2008 (Standard) SP 1
Windows 7 SP 1

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Table.compute - String zuvor in Double umwandeln 
Autor: Bingopark
Datum: 17.01.10 02:41

Danke Keco!

Die Befehle waren mir bereits schon mal in die Finger gekommen... Ich war allerdings nicht erfolgreich diese in meinen Code (s. meinen Beitrag) vernünftig einzubauen. Bei mir kamen je nach Art der Verwendung verschiedene Fehlermeldungen, die darauf schließen ließen, dass ich vermutlich die Syntax nicht korrekt angewandt habe.

Bingopark

----
Meine Komponenten sind:
Visual Studio 2008 (Standard) SP 1
Windows 7 SP 1

Beitrag wurde zuletzt am 17.01.10 um 02:42:28 editiert.

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Table.compute - String zuvor in Double umwandeln 
Autor: ModeratorDaveS (Moderator)
Datum: 17.01.10 09:20

Wenn du die DataTable-Spalten vorher richtig deklarierst wird die Xml auch richtig eingelesen, und Methoden wie .Compute() klappen auch. Das geht mit einem Schema (intern oder als .xsd) oder einfach mit Code. Mit dieser Xml zB kann man die Teilnehmer-Tabelle so im Voraus anlegen
        Dim ds As New DataSet
 
        Dim dt As New DataTable("Teilnehmer")
        dt.Columns.Add("Nr", GetType(Integer)).ColumnMapping = _
          MappingType.Attribute
        dt.Columns.Add("Name", GetType(String))
        dt.Columns.Add("Punkte", GetType(Integer))
 
        ds.Tables.Add(dt)
 
        ds.ReadXml(...)
(Dann werden die Spalten auch richtig sortiert).

________
Alle Angaben ohne Gewähr. Keine Haftung für Vorschläge, Tipps oder sonstige Hilfe, falls es schiefgeht, nur Zeit verschwendet oder man sonst nicht zufrieden ist

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Table.compute - String zuvor in Double umwandeln 
Autor: ModeratorDaveS (Moderator)
Datum: 17.01.10 12:03

Bei einfachen Sachen geht es auch mit der InferTypedSchema-Option bei .ReadXml().

________
Alle Angaben ohne Gewähr. Keine Haftung für Vorschläge, Tipps oder sonstige Hilfe, falls es schiefgeht, nur Zeit verschwendet oder man sonst nicht zufrieden ist

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Table.compute - String zuvor in Double umwandeln 
Autor: Bingopark
Datum: 17.01.10 12:47

Danke!
Ich bin gerade dabei die verschiedenen Möglichkeiten durchzuspielen, wobei ich mir gerade nochmals Gedanken zu meiner grundsätzlichen Vorgehensweise im Hinblick auf mein Ziel mache:

Mein Ziel: der Anwender soll für einige Datenspalten Mittel-/Min- und Maxwert sowie z.B. 90. Perzentil, Standardabweichung etc. der Messgrößen dargestellt bekommen.

Das muss nicht in der Tabelle selbst passieren. Vielleicht sollte ich die Spaltenwerte eher in ein Array schreiben, dort die Berechnungen durchführen und die Ergebnisse dem Anwender präsentieren. Dann könnte ich wahrscheinlich auch komplexere Berechnungen als die der Mittelwert-, Min- und Maxwerte durchführen und die Felder einfach "String" sein lassen.

Unschlüssig & weiterhin für Rat offen
Bingopark

----
Meine Komponenten sind:
Visual Studio 2008 (Standard) SP 1
Windows 7 SP 1

Beitrag wurde zuletzt am 17.01.10 um 12:48:32 editiert.

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel