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


MoveMemory

Postades av 2003-01-03 02:15:16 - Raderat konto, i forum visual basic - allmänt, Tråden har 3 Kommentarer och lästs av 373 personer

Hej,

Kan någon förklara varför felmeddelandet 458 uppstår i nedanstående kod och hur det kan lösas?

Tack på förhand,
Dennis

<code>
Option Explicit

Public Declare Sub MoveMemory Lib "kernel32" Alias "RtlMoveMemory" _
(Destination As Any, Source As Any, ByVal Bytes As Long)

Sub Split_Transfer_Add_Sheet_65536()
Dim fsoObj As Scripting.FileSystemObject
Dim fsoFile As Scripting.file
Dim fsoTS As Scripting.TextStream
Dim vaData As Variant, vaTarget() As Variant
Dim lnNoFiles As Long, lnNumberRows As Long
Dim dbCount As Double
Dim j As Long, i As Long

Const lnMaxRows As Long = 65536

Set fsoObj = New Scripting.FileSystemObject
Set fsoFile = fsoObj.GetFile("e:\Test\test.txt")
Set fsoTS = fsoFile.OpenAsTextStream(ForReading, TristateFalse)

vaData = Split(fsoTS.ReadAll, vbNewLine, , vbBinaryCompare)

lnNumberRows = UBound(vaData) + 1

If lnNumberRows <= lnMaxRows Then
MsgBox "Can´t split the file - number of rows <= 65536 rows.", vbExclamation
fsoTS.Close
Exit Sub
Else
fsoTS.Close
End If

lnNoFiles = Int(lnNumberRows / lnMaxRows)
dbCount = lnNumberRows Mod lnMaxRows
If dbCount > 0 Then
lnNoFiles = lnNoFiles + 1
End If

Application.ScreenUpdating = False

i = 0
For j = 1 To lnNoFiles
If j <> lnNoFiles Then
Erase vaTarget
ReDim vaTarget(0 To 65536)
MoveMemory vaTarget(0), vaData(i), i + lnMaxRows
Worksheets.Add
Cells(1, 1).Resize(65536).Value = TransposeData(vaTarget)
i = i + lnMaxRows
Else
i = lnNumberRows - (lnNoFiles - 1) * lnMaxRows
Erase vaTarget
ReDim vaTarget(0 To lnNumberRows)
MoveMemory vaTarget(0), vaData(i), lnNumberRows
Worksheets.Add
Cells(1, 1).Resize(i).Value = TransposeData(vaTarget)
End If
Next j

Set fsoTS = Nothing
Set fsoFile = Nothing
Set fsoObj = Nothing
Set vaData = Nothing
Erase vaTarget
Application.ScreenUpdating = True

End Sub

Function TransposeData(Matris As Variant) As Variant
Dim vaDataMatris() As Variant
Dim i As Long

ReDim vaDataMatris(LBound(Matris) To UBound(Matris), _
LBound(Matris) To LBound(Matris))
For i = LBound(vaDataMatris) To UBound(vaDataMatris)
'Här stoppas proceduren och felmeddelandet error 458 visas <------------
vaDataMatris(i, LBound(vaDataMatris)) = Matris(i)
Next i

TransposeData = vaDataMatris

End Function
</code>


Svara

Sv: MoveMemory

Postades av 2003-01-03 02:36:00 - Mattias Sjögren

>Kan någon förklara varför felmeddelandet 458 uppstår i nedanstående kod och hur det kan lösas?

Vet itne exakt vad som orsakar felet, men du kan inte göra en direkt minneskopia av Variant variabler med MoveMmeory så där, eftersom de kan innehålla pekare till allokerat minne, och systemet då kommer försöka frigöra samma minne flera gånger.

Varför använder du MoveMemory över huvud taget, iställer för vanlig tilldelning?


MS


Svara

Sv: MoveMemory

Postades av 2003-01-03 02:46:08 - Andreas Hillqvist

Variable uses a type not supported in Visual Basic (Error 458)

Det skulle hjälpa om du berättar hur din fil såg ut och vad du vill göra.

Du får vara försiktig med MoveMemmory. Om informationen inte har rätt format så blir det. Variant datatypen har en header som talar om vad det är för datatyp. KAn vara så att du skrivit över den med din data.


Svara

Sv: MoveMemory

Postades av 2003-01-03 02:59:42 - Raderat konto

Hej MS,

"Varför använder du MoveMemory över huvud taget, iställer för vanlig tilldelning?"

Jo, jag försöker hantera textfiler i storleksordning 40-50 MB....och det jag eftersträvar är att minimera tidsåtgången (Jo, jag vet att Acces/MySQL etc är bättre alternativ men jag är hänvisad till XL...)

Jag har en ADO-baserad lösning men den fungerar inte i 97:an...
Jag har även tagit fram en lösning baserad på traditionell "array-slicing" som fungerar men som tar en evighet...

Hej Andreas,
"Variant datatypen har en header som talar om vad det är för datatyp. KAn vara så att du skrivit över den med din data."

Intressant och jag tror att det mycket möjligt kan ligga i detta - Hur tar jag reda på det?

Dennis


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 170
27 953
271 705
573
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