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


Alla tecken i räknare

Postades av 2007-07-24 21:39:26 - Thomas Roman, i forum mysq, Tråden har 17 Kommentarer och lästs av 1339 personer

Går det att ange vilka tecken som ska användas för en ID-räknare, så att den räknar 0-9, sen a-z, sen A-Z och sen börjar om med 00, 01 osv?


Thomas


Svara

Sv: Alla tecken i räknare

Postades av 2007-07-24 22:25:43 - Johan Djupmarker

Vet ej om det går, men en workaround skulle vara att lagra heltal och omvandla det sedan.

/Johan


Svara

Sv:Alla tecken i räknare

Postades av 2007-07-24 22:32:00 - Thomas Roman

Ja jag har tänkt på det jag också. Har du någon smart lösning för hur man enklast gör den konverteringen? Om man kan ange vilka tecken som ska kunna användas så är det bra, men det duger definitivt med 0-9, a-z och A-Z.


Thomas


Svara

Sv: Alla tecken i räknare

Postades av 2007-07-24 23:16:39 - Johan Djupmarker

I C# skulle du kunna göra såhär:

        private const string TillatnaTecken = "0123456789ABCDEF";

        private static string TalTillText(int Tal)
        {
            string Text = string.Empty;
            int Resterande = Tal;

            while (Resterande > 0)
            {
                int Index = (Resterande % Convert.ToInt32(Math.Pow(TillatnaTecken.Length, Text.Length + 1)) / Convert.ToInt32(Math.Pow(TillatnaTecken.Length, Text.Length)));
                Text = TillatnaTecken.Substring(Index, 1) + Text;
                Resterande -= Index * Convert.ToInt32(Math.Pow(TillatnaTecken.Length, Text.Length - 1));
            }
            return Text;
        }

        private static int TextTillTal(string Text)
        {
            int Tal = 0;

            for (int i = 0; i < Text.Length; i++)
            {
                Tal += TillatnaTecken.IndexOf(Text.Substring(Text.Length - 1 - i, 1)) * Convert.ToInt32(Math.Pow(TillatnaTecken.Length, i));
            }
            return Tal;
        }


Svara

Sv: Alla tecken i räknare

Postades av 2007-07-25 09:12:48 - Andreas Hillqvist

Kanske lättare att göra om löpnummret till en alfanumerisk ID och alfanumerisk ID till löpnummer. I databasen använda en vanlig räknare som du formaterar vid visning.


Svara

Sv:Alla tecken i räknare

Postades av 2007-07-25 11:17:54 - Thomas Roman

Ja, det är väl det som Johan föreslog. Eller tänkte du på något annat? Du har kanske en bättre lösning?


Thomas


Svara

Sv: Alla tecken i räknare

Postades av 2007-07-26 08:27:28 - Andreas Hillqvist

Jag missade Johans inlägg, Men typ något sådant.


Svara

Sv:Alla tecken i räknare

Postades av 2007-07-26 16:10:09 - Thomas Roman

Jag håller på och konverterar koden till vanlig ASP men jag får det inte riktigt att fungera.
<code>
Response.Write ValToText(1) & "<br>" 'Ska bli 1
Response.Write ValToText(16) & "<br>" 'Ska bli f

Function ValToText(ByVal Nr)
AllowedChars = "1234567890abcdef"
Text = ""
Rest = Nr
Do While Rest > 0
Index = (Rest Mod CInt(Len(AllowedChars) ^ (Len(Text) + 1)) / CInt(Len(AllowedChars) ^ Len(Text)))
Text = Mid(AllowedChars, Index, 1) & Text 'rad 11
Rest = Rest - (Index * CInt(Len(AllowedChars) ^ (Len(Text) -1)))
Loop
ValToText = Text
End Function
</code>

Jag får felet:
<info>
Microsoft VBScript runtime error '800a0005'

Invalid procedure call or argument: 'Mid'

/test_convert.asp, line 11
</info>

Jag trodde ett tag att felet berodde på avrundningsskillnader mellan Convert.ToInt32 och CInt men jag testade att ändra till Fix och Int och det gjorde ingen skillnad.


Thomas


Svara

Sv: Alla tecken i räknare

Postades av 2007-07-26 16:41:02 - Johan Djupmarker

När man använder Mid är första tecknet 1 och inte 0, det ska därför vara:

Mid(AllowedChars, Index - 1, 1) & Text

/Johan


Svara

Sv:Alla tecken i räknare

Postades av 2007-07-26 22:19:46 - Thomas Roman

Antar att du menade +1 men det hjälpte inte, då blev ValToText(1) 2 istället för 1. Nu vet jag inte vad jag har gjort för fel, men 1-15 ger rätt resultat, 16 som ska bli f orsakar samma fel.
<code>
Response.Write ValToText(1) & "<br>"
Response.Write ValToText(15) & "<br>"
Response.Write ValToText(16) & "<br>"

Function ValToText(ByVal Nr)
AllowedChars = "1234567890abcdef"
Text = ""
Rest = Nr
Do While Rest > 0
Index = (Rest Mod (Len(AllowedChars) ^ (Len(Text) + 1)) / (Len(AllowedChars) ^ Len(Text)))
Text = Mid(AllowedChars, Index, 1) & Text
Rest = Rest - (Index * (Len(AllowedChars) ^ (Len(Text) -1)))
Loop
ValToText = Text
End Function
</code>


Thomas


Svara

Sv: Alla tecken i räknare

Postades av 2007-07-26 22:43:56 - Johan Djupmarker

Givetvis menade jag +1. Anledningen till att du fick fel resultat när du gjorde så är att du har satt 0 på fel ställe i strängen. Sätt den först istället.

Text = Mid(AllowedChars, Index, 1) & Text

/Johan


Svara

Sv:Alla tecken i räknare

Postades av 2007-07-27 00:14:32 - Thomas Roman

<code>
Response.Write ValToText(1) & "<br>" 'Ger 1
Response.Write ValToText(15) & "<br>" 'Ger f
Response.Write ValToText(16) & "<br>" 'Ger 00000000000000000000... (oändligt tror jag)

Function ValToText(ByVal Nr)
AllowedChars = "0123456789abcdef"
Text = ""
Rest = Nr
Do While Rest > 0
Index = (Rest Mod (Len(AllowedChars) ^ (Len(Text) + 1)) / (Len(AllowedChars) ^ Len(Text)))
Text = Mid(AllowedChars, Index +1, 1) & Text
Rest = Rest - (Index * (Len(AllowedChars) ^ (Len(Text) -1)))
Loop
ValToText = Text
End Function
</code>

Resultatet blir inte helt rätt...


Thomas


Svara

Sv: Alla tecken i räknare

Postades av 2007-07-27 00:51:40 - Johan Djupmarker

Nu gissar jag vilt (utan att testa), skulle det kunna vara så att detta uttrycket evalueras i fel ordning och att det ska vara såhär istället?`

Index = (Rest Mod (Len(AllowedChars) ^ (Len(Text) + 1))) / (Len(AllowedChars) ^ Len(Text))

/Johan


Svara

Sv:Alla tecken i räknare

Postades av 2007-07-27 01:01:03 - Thomas Roman

Nu fungerar det! Ska påbörja jobbet med att konvertera åt andra hållet och återkommer med resultatet.


Thomas


Svara

Sv: Alla tecken i räknare

Postades av 2007-07-27 01:45:27 - Thomas Roman

Den andra konverteringen vill inte fungera.

<code>
Response.Write TextToVal(ValToText(1)) & "<br>"
Response.Write TextToVal(ValToText(15)) & "<br>"
Response.Write TextToVal(ValToText(16)) & "<br>"

Function ValToText(ByVal Nr)
AllowedChars = "0123456789abcdef"
Text = ""
Rest = Nr
Do While Rest > 0
Index = (Rest Mod (Len(AllowedChars) ^ (Len(Text) + 1))) / (Len(AllowedChars) ^ Len(Text))
Text = Mid(AllowedChars, Index +1, 1) & Text
Rest = Rest - (Index * (Len(AllowedChars) ^ (Len(Text) -1)))
Loop
ValToText = Text
End Function

Function TextToVal(ByVal Text)
AllowedChars = "0123456789abcdef"
Nr = 0
X = 0
Do While X < Len(Text)
X = X +1
Nr = Nr + (InStr(AllowedChars, Mid(Text, Len(Text) -1 -X, 1)) * Len(AllowedChars) ^ X) 'Rad 28
Loop
TextToVal = Nr
End Function
</code>

<info>
Microsoft VBScript runtime error '800a0005'

Invalid procedure call or argument: 'Mid'

/test_convert.asp, line 28
</info>

Jag har för mig att IndexOf och Substring fungerar lite annorlunda mot InStr och Mid och jag har försökt att justera koden för det men det blev inte bättre så jag tog bort den förändringen.


Thomas


Svara

Sv:Alla tecken i räknare

Postades av 2007-07-27 12:49:29 - Johan Djupmarker

Såhär ska det vara:

<code>
Function TextToVal(ByVal Text)
AllowedChars = "0123456789abcdef"
Nr = 0
X = 0
Do While X < Len(Text)
'msgbox Mid(Text, Len(Text) - X, 1)
'msgbox (InStr(AllowedChars, Mid(Text, Len(Text) - X, 1) - 1)
Nr = Nr + (InStr(AllowedChars, Mid(Text, Len(Text) - X, 1)) - 1) * (Len(AllowedChars) ^ X)
X = X + 1
Loop
TextToVal = Nr
End Function
</code>

/Johan


Svara

Sv: Alla tecken i räknare

Postades av 2007-07-27 17:04:38 - Thomas Roman

Perfekt!
Jag får tacka så mycket!


Thomas


Svara

Sv:Alla tecken i räknare

Postades av 2007-07-27 18:50:59 - Johan Djupmarker

Oops, fick visst med lite bortkommenterade debug-prylar :)

Kul att det löste sig!

/Johan


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 153
27 952
271 704
840
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