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


Räkna i ASP eller VBS

Postades av 2006-03-24 20:11:56 - Torsten Josefsson, i forum asp - allmänt, Tråden har 8 Kommentarer och lästs av 639 personer

Följande kod återskapar problemet! Kan någon svara på varför det blir såhär?

<code>
Num1 = "123.4567"
Num2 = "123.4567"

WScript.Echo "Ska bli 246,9134"
WScript.Echo Num1 + Num2 ' Blir 123.4567123.4567
WScript.Echo replace(Num1,".",",") + replace(Num2,".",",") ' Blir 123,4567123,4567
WScript.Echo (Num1*1) + (Num2*1) ' Blir 2469134
WScript.Echo (replace(Num1,".",",")*1) + (replace(Num2,".",",")*1) ' Blir 246,9134
</code>

Med följande blir det givetvis något helt annat.

<code>
Num1 = 123.4567
Num2 = 123.4567
</code>

Jag kör Win XP på svenska.


Svara

Sv: Räkna i ASP eller VBS

Postades av 2006-03-24 20:40:37 - Anna-Karin Söderberg

Testa att göra om dem till tal med cLng eller cDbl innan du plussar ihop dem.

//Anna-Karin


Svara

Sv:Räkna i ASP eller VBS

Postades av 2006-03-24 22:18:13 - Torsten Josefsson

Jag har testat de flesta varianter av cLng, cDbl och allt vad de heter. Ytterligare en test enligt nedan ger 2469134. Jag ser inte, fattar inte, mönstret med komma, punkt och hur man ändrar "123.4567" till 123.4567 så att ASP/VBS räknar rätt.

<code>
WScript.Echo cLng(Num1) + cLng(Num2) ' Blir 2469134
WScript.Echo cDbl(Num1) + cDbl(Num2) ' Blir 2469134

num3 = cLng(Num1)
num4 = cLng(Num2)
num5 = cDbl(Num1)
num6 = cDbl(Num2)
WScript.Echo num3 + num4 ' Blir 2469134
WScript.Echo num5 + num6 ' Blir 2469134
</code>


Svara

Sv: Räkna i ASP eller VBS

Postades av 2006-03-25 22:50:13 - Martin Adrian

VBS är lite jobbigt när det gäller strängar och operatorn +

Huvudidén är att om de båda termerna går att konvertera till tal så blir resultatet en beräkning med tal annars en konkatenering av strängar.
dvs
"1" + "2" = 3
"A" + "B" = "AB"

(Personligen tycker jag att det vore bättre om "1" + "2" blir "12")

Ditt problem är antagligen sättet som VBS avgör om en sträng går att konvertera till ett tal eller inte. Detta beror på datorns nationella inställningar.
I Sverige där vi använder decimalkomma anses "1,2" vara ett tal medan "1.2" inte är ett tal.
I USA där man använder decimalpunkt är det tvärt om.

Eftersom du nu har två strängar som innehåller tal formatterade på amerikanskt vis kommer de inte anses vara tal på en dator med svensk inställning.

Prova följande kod
<code=vb>
Function CDblPoint(str)
Dim original
original = SetLocale("en-us") ' ställ om till amerikansk formattering
CDblPoint = CDbl(str)
SetLocale(original) ' återställ
End Function

msgbox CDblPoint("123.4567")
</code>


Svara

Sv:Räkna i ASP eller VBS

Postades av 2006-03-27 14:21:39 - Torsten Josefsson

Tack både Frerik och Martin för Era svar!

Martins funktion fungerar fint men jag ser fortfarande inte mönstret. Man kanske inte kan se mönster med VBS, det verkar ju göra lite som det vill ibland. Martin skriver att i Sverige där vi använder decimalkomma anses "1,2" vara ett tal medan "1.2" inte är ett tal. Jag får följande:
<code>
SetLocale("en-us")
WScript.Echo "10,5" + "10,5" ' Blir 10,510,5
WScript.Echo 10,5 + 10,5 ' Blir 10 15 5
WScript.Echo "10.5" + "10.5" ' Blir 10.510.5
WScript.Echo 10.5 + 10.5 ' Blir 21

SetLocale("sv-se")
WScript.Echo "10,5" + "10,5" ' Blir 10,510,5
WScript.Echo 10,5 + 10,5 ' Blir 10 15 5
WScript.Echo "10.5" + "10.5" ' Blir 10.510.5
WScript.Echo 10.5 + 10.5 ' Blir 21
</code>
Ingen skillnad alltså för dessa varianter. Här är dock en skillnad, som Martins funktion även visar:
<code>
SetLocale("en-us")
WScript.Echo CDbl("10.5") + CDbl("10.5") ' Blir 21

SetLocale("sv-se")
WScript.Echo CDbl("10.5") + CDbl("10.5") ' Blir 210
</code>
Hur var det med CDbl och max- och minvärden, det var väl bara CLng som måste ha tal inom visst intervall?


Svara

Sv: Räkna i ASP eller VBS

Postades av 2006-03-27 15:19:50 - Andreas Hillqvist

Val utgår från punkt som decimalseparator. Jag rekomenderar därför följande kod:

Function Number(value)
    Number = Val(Replace(value, ",", "."))
End Function

Dim Num1
Dim Num2
    Num1 = Number("123.4567")
    Num2 = Number("123.4567")

    WScript.Echo "Ska bli 246,9134"
    WScript.Echo Num1 + Num2 


Svara

Sv:Räkna i ASP eller VBS

Postades av 2006-03-27 16:34:11 - Torsten Josefsson

Jag får bara "inkompatibla typer" av Val(). Jag tror att Val() inte finns i VBScript och i ASP, utan bara i VB.


Svara

Sv: Räkna i ASP eller VBS

Postades av 2006-03-27 16:52:42 - Andreas Hillqvist

Tänkte inte på det. ;o)


Svara

Nyligen

  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo
  • 14:25 Tips på verktyg för att skapa QR-k
  • 14:23 Tips på verktyg för att skapa QR-k
  • 20:52 Fungerer innskuddsbonuser egentlig

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 569 600
27 953
271 705
4 092
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