VB.net?quote:Op vrijdag 20 juli 2007 16:39 schreef Chandler het volgende:
Sr
Nog 1 vraagje.
Ik werk nu met line input, echter werkt dit bij 1 groot tekst bestand niet.. Line input ziet niet dat het een tekst bestand is en leest gelijk het hele bestand uit... wat kan ik hier aan veranderen zodat hij wel alle regels leest?
Anyone?
quote:A line is defined as a sequence of characters followed by a carriage return (0x000d), a line feed (0x000a), a carriage return followed by a line feed, Environment.NewLine, or the end of stream marker. The string that is returned does not contain the terminating carriage return and/or line feed. The returned value is a null reference (Nothing in Visual Basic) if the end of the input stream has been reached.
Ik hoop dat het werkt, want die converter kan geen UTF-8 tekens converteren erg onhandig... output van een 60MB file is gewoon dom weg 5.nogwat MB (na draaien in mijn progie, end door eof!)quote:Op vrijdag 20 juli 2007 20:12 schreef SuperRembo het volgende:
Met een TextReader zou het moeten kunnen. ReadLine geeft 1 regel terug:
De TextReader class bestaat al sinds .NET 1.0. Het lijkt me niet dat er heel veel in veranderd is.quote:Op vrijdag 20 juli 2007 21:26 schreef Chandler het volgende:
This page is specific to .NET Framework 3.0
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | While Not readBytes >= fileSize 'EOF(freeNum) ' Line Input #FreeNum, txt ' 1 whole line is read Do While readByte <> Chr(10) Get #freeNum, , readByte Debug.Print Len(txt) & "-" & Len(readByte) & "-" & Asc(readByte) txt = txt & readByte Loop readBytes = readBytes + Len(txt) loop |
1 2 3 4 5 6 7 8 | Dim reader As New System.IO.StreamReader("C:/foo.txt") While Not reader.EndOfStream line = reader.ReadLine() '... End While reader.Close() |
Visual Studio Express is gratis.quote:Op zaterdag 21 juli 2007 12:24 schreef Chandler het volgende:
Ik heb helaas geen VBnet... (jawel, maar weet niet waar, moet toch ook gewoon in vb6 kunnen, zoals bovenstaand maar dan anders...)
Geen idee, ik ben niet zo thuis in die VB6 file handling.quote:Ennuh opzich is mijn code toch wel juist?
1 2 3 4 5 6 7 8 9 10 | Get #freeNum, pointCnt, readByte readBytes = readBytes & Chr(readByte) pointCnt = pointCnt + 1 Debug.Print readByte Debug.Print pointCnt & " - " & fileSize & " - " & Len(readBytes) & vbCrLf Loop While (readByte <> 13 Or pointCnt < fileSize) |
Vreemt. Wat je zou kunnen proberen is in plaats van een Do loop een For loop gebruiken. Dan zou het worden:quote:Op zondag 22 juli 2007 15:50 schreef Chandler het volgende:
Hmm... Lijkt mij toch wel aardig goed te zijn :P
Ik heb mijn code een beetje aangepast en heb dit nu in een loop staan.
[ code verwijderd ]
echter wil de loop niet stoppen als readByte (10 of 13) is :{ Wat doe ik fout? :D
1 2 3 4 5 6 7 8 9 10 | Get #freeNum, I, readByte readBytes = readBytes & Chr(readByte) Debug.Print readByte Debug.Print I & " - " & fileSize & " - " & Len(readBytes) & vbCrLf If readByte = 13 Then Exit For Next I |
1 2 3 4 5 6 7 8 9 10 11 | Dim fso, myFile As Object Dim line As String Set fso = New Scripting.FileSystemObject Set myFile = fso.OpenTextFile("c:foo.txt", forReading) Do While Not myFile.AtEndOfStream line = myFile.ReadLine '... Loop myFile.Close |
1 |
1 |
1 2 3 4 5 6 7 8 9 10 11 12 | Dim strNum As String Dim i As Integer On Error Resume Next For i = 1 To Len(strValue) If IsNumeric(Mid(strValue, i, 1)) Then strNum = strNum & Mid(strValue, i, 1) Next i ExtNum = CInt(strNum) End Function |
Les 1: nooit "on error resume next" gebruiken tijdens debuggen!quote:Op zaterdag 10 mei 2008 14:02 schreef Woeiii het volgende:
Ben bezig met een kleine functie om een getal van 6 aaneensluitende nummers uit een string te halen, maar t wil niet echt lukken:
[ code verwijderd ]
Deze haalt alle getallen uit een lap tekst , maar werkt niet goed hij returned namelijk steeds nul , heeft iemand een oplossing?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | Dim strNum As String Dim i As Integer 'On Error Resume Next For i = 1 To Len(strValue) If IsNumeric(Mid(strValue, i, 1)) Then strNum = strNum & Mid(strValue, i, 1) Next i ExtNum = Val(strNum) 'On Error GoTo 0 End Function |
De truuk is net dat je die code zelf moeten maken.quote:Op dinsdag 7 oktober 2008 10:54 schreef hello_moto1992 het volgende:
Sorry voor de grote kick, maar...
Ik zou graag een programma willen maken dat een rekening bij houdt in een kantine/keet. Je hebt dus een lijstje met namen, en daar achter staat bier, wijn, cola, malibu etc.
In Excel kun je "view code" doen, maar dan staat er niks. Hoe kan dat?
En hoe maak ik het handigste zo'n programma?
Ik kwam er ook achter .quote:Op dinsdag 7 oktober 2008 11:07 schreef DaFan het volgende:
Kan je beter in het Excel topic doen.
[EXCEL] Het grote Excel vragen topic, #7
En onder View code is het de bedoeling dat je zelf de code schrijft
vb kan je redelijk simpel met mysql laten comminicerenquote:Op dinsdag 7 oktober 2008 11:19 schreef DaFan het volgende:
In VB is het een stuk lastiger omdat je geen 'database' hebt. Als je het in Excel icm VBA doet heb je gewoon een overzicht waar je idd gewoon een knopje kan drukken achter iemands naam, waarbij hij de waarde opzoekt die het nu is, en er 1 bij optelt. Simpel.
Akkoord maar niet voor een dranklijst en al helemaal niet als je nog nooit VB gebruikt hebtquote:Op dinsdag 7 oktober 2008 21:29 schreef mschol het volgende:
[..]
vb kan je redelijk simpel met mysql laten comminiceren
Als het toch op 1 PC draait zou ik eerder SQLLite of misschien Firebird gebruiken.quote:Op dinsdag 7 oktober 2008 21:29 schreef mschol het volgende:
[..]
vb kan je redelijk simpel met mysql laten comminiceren
1 2 | FileExists = oFile.FolderExists(sFullPath) |
Je gebruikt geen Option Explicit (aan het begin van je code staat in ieder bestand).quote:Op donderdag 20 mei 2010 14:02 schreef Chandler het volgende:
Idd, ik kwam er achter dat een letter qua functienaam niet goed stond en dus geen true/false (boolean) terug stuurde.. wat kun je toch over foutjes heen kijken zeg
1 |
quote:Op donderdag 20 mei 2010 14:26 schreef Chandler het volgende:
-edit-
Ini werkt al
Alles werkt op het maken van directories na... en op een of andere manier kom ik daar niet uit..
Maar ik ga er nu even lekker mee spelen!
VB6 nog? Je weet dat Microsoft inmiddels van haar .net-versies ook gratis versies van de ontwikkelstudio's uitbrengt? Onder andere Visual Basic .net 2008 is gratis te downloaden: http://www.microsoft.com/exPress/quote:Op vrijdag 21 mei 2010 15:53 schreef Chandler het volgende:
Hier te downloaden in source van visualbasic 6
Het mooie van VB.net is dat de syntax onveranderd is maar dat het op sommige punten eenvoudiger is om - bijvoorbeeld met het bestandsysteem - te werken. Om je een voorbeeld te noemen, in vb.net is er standaard een functie aanwezig om te controleren of een bestand bestaat: System.IO.File.Exists(path as string). Dat scheelt, want dan hoef je filesystemobject niet steeds opnieuw te declareren.quote:Op vrijdag 21 mei 2010 17:23 schreef Chandler het volgende:
Ja VB6 hoe durf ik hoor ik je nu denken, ach het is voor mij bekender, aangezien ik zelf altijd met QuickBASIC 4.5 heb gwerkt (jaren, jaren jaren geleden! ) en dus simpeler om te begrijpen... En natuurlijk het belangrijkste, het lukt me om er iets mee te bakken! maar goed, wie weet ga ik ooit eens .net proberen... maar dat zal pas na een volgende herinstal worden
Heb je nog tips voor de huidige code?
1 2 | MsgBox(bestandsinformatie.Extension) |
"vol" lopen van het geheugen?quote:Op zondag 23 mei 2010 11:23 schreef Chandler het volgende:
Nou geheugen valt dus tegen... 50-80mb erg schommelend... Ook gaan de eerste 10.000 bestanden aardig rap maar daarna gaat het steeds slomer... iemand een idee waardoor dit zou kunnen komen?
Leuk om te zien dat het werkt! Je zou i.p.v. "AND" ook "ANDALSO" kunnen gebruiken, dat zal iets in performance schelen. In dit voorbeeld:quote:Op zaterdag 22 mei 2010 16:23 schreef Chandler het volgende:
Dan maar weer een kleine update, zelfde bestand.
Aardig wat ifjes verwijderd.
nu 1 aanroep voor alle fso objecten
meer gegevens in error string.
En een exe toegevoegd... weet niet of dat handig is maar goed :)
Gaat nu zeker een stuk sneller, en volgens mij eet het ook minder geheugen..
1 |
1 |
Grappig dat dat zo erg scheelt :)quote:Op zondag 23 mei 2010 22:01 schreef Chandler het volgende:
Yup, dat was idd het euvel, voor ieder bestand dat na controle op datum geskipt werdt was terug te vinden in de log en dat is met 200k aan bestande niet grappig... nu deze weg gehaalt zit het geheugen gebruik op 5MB en loopt het nu alle bestanden in zo'n 5 minuten langs!!!! ipv een halve dag :D
dat lijkt me vb.net en dat is iets waar de meeste mensen in dit topic allergisch voor zijn.quote:Op maandag 3 januari 2011 19:06 schreef Modus het volgende:
Ik ben met een studieopdracht bezig. Een simpel programmaatje om een soort orderlijst te maken en daarnaast moet je nog een programma maken om die orderlijst te veranderen. Ik moet dus 2 .exe's maken (kan ms ook anders maar het voorbeeld heeft er ook 2).
Min of meer de enige hint die gegeven werd voor het samen gebruiken van die 2 is dat VB (Express in mijn geval) een Process component in de toolbox heeft. Ik heb echter geen idee hoe en wat verder, als ik zo'n ding in mijn eerste programma toevoeg.
In prog 1 zit een knop Edit orderlist die prog 2 laat opstarten. Ik heb echt geen idee wat voor code ik ongeveer zou moeten gebruiken onder die knop om dat voor elkaar te krijgen. En als ik wel code heb, wat is dan het nut van dat component in mijn project??
Verder is dus het idee dat gegevens uit prog 2 weer verwerkt worden in prog 1. Ook geen idee hoe dat zou moeten (variabelen binnen meerdere forms snap ik wel), of gaat dat min of meer 'automatisch' door juist gebruik van dit onderdeel?
Heb hier al wat zitten kijken http://msdn.microsoft.com(...)nostics.process.aspx maar daar word ik niet heel veel wijzer van vooralsnog.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load If Environment.GetCommandLineArgs.Contains("edit") Then Dim orders As New List(Of String) Dim order As String = Nothing Do order = Console.ReadLine If order <> String.Empty Then orders.Add(order) Loop While Not order = String.Empty MessageBox.Show(orders.Count) Else Dim orderLijst As String() = {"cola", "boter", "kaas", String.Empty} Dim si As New System.Diagnostics.ProcessStartInfo With { .Arguments = "edit", .FileName = Application.ExecutablePath, .RedirectStandardInput = True, .UseShellExecute = False } Dim process = System.Diagnostics.Process.Start(si) process.WaitForInputIdle() For Each order In orderLijst process.StandardInput.WriteLine(order) Next process.StandardInput.Flush() End If End Sub |
Volgens mij is het gewoon de bedoeling dat ze die data in een textfile of DB opslaan. Snap niet dat mensen hier rare oplossingen als communicerende applicaties gaan bedenken. In VB wat in een access DB frutten is triviaal.quote:Op maandag 3 januari 2011 21:28 schreef Core2 het volgende:
Het is dan ook niet zo moeilijk meer om van B naar A te gaan lijkt me. Je kunt dus communiceren via stdin/stdout. Je hebt nog wel wat andere mogelijkheden (named pipes, memory mapped files, tcp/ip, etc) waar je denk ik nog wat te weinig ervaring voor hebt (met alle respect ).
Je kunt die opdracht op meerdere manieren interpreteren, ik heb geen idee wat de context is. Er wordt gesproken over het Process object, een orderlijst en twee applicaties die iets met die orderlijst moeten doen. Niet zo gek dat je dan bij communicerende processen uitkomt, maar zou me niks verbazen als ze inderdaad een database oplossing bedoelen.quote:Op dinsdag 4 januari 2011 14:39 schreef Catbert het volgende:
[..]
Volgens mij is het gewoon de bedoeling dat ze die data in een textfile of DB opslaan. Snap niet dat mensen hier rare oplossingen als communicerende applicaties gaan bedenken. In VB wat in een access DB frutten is triviaal.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | Dim File_Name As String = "D:\vb08sbs\voorbeelden\899J6\Inzending\899Q6\orders.txt" If System.IO.File.Exists(File_Name) = True Then Dim SplitLineArr() As String, NewTextLine As String Dim objReader As New System.IO.StreamReader(File_Name) Do While objReader.Peek() <> -1 NewTextLine = objReader.ReadLine() SplitLineArr = Split(objReader.ReadLine(), ";") Label5.Text = NewTextLine Label6.Text = SplitLineArr(0) ' Dim index As Integer = OrderListBox.FindString(SplitLineArr(0)) ' If index <> -1 Then ' OrderListBox.Items(index) = NewTextLine ' ArticlePrice = Convert.ToDecimal(Trim(SplitLineArr(2)), New System.Globalization.CultureInfo("en-US")) ' TotalPrice = TotalPrice + (Trim(SplitLineArr(3)) * ArticlePrice) ' End If Loop End If |
Je leest nu door deze code steeds twee regels uit het bestand.quote:Op maandag 1 augustus 2011 21:26 schreef Modus het volgende:
Thanks, had je reply nog niet gezien. Ik heb dat stukje inmiddels ook werkend kunnen krijgen. Ben inmiddels weer iets verder gevorderd.
Nu wat anders, een wat specifieker probleem, dus ms makkelijker om uit te zoeken.
Na het sluiten van App2 laat ik het txt-bestand opnieuw openen, dat moet regel voor regel uitgelezen worden, elke regel moet opgesplitst naar een array en het eerste item van deze array moet als zoekterm gebruikt worden om in de Listbox van App1 het bijbehorende item terug te vinden.
Leek allemaal goed te gaan maar het juiste Listbox.Item wordt niet goed bijgewerkt. Nader onderzoek leert dat die array vullen niet goed gaat, maar ik zie niet wat ik daar fout aan doe. Heb ongeveerd e volgende code:
[ code verwijderd ]
1 2 | NewTextLine = objReader.ReadLine() SplitLineArr = Split(objReader.ReadLine(), ";") |
1 | SplitLineArr = Split(NewTextLine , ";") |
Het enige wat deze Do zegt is dat er code moet worden uitgevoerd zolang er nog tekst te vinden is in het bestand. Met .Peek() kijk je namelijk naar de volgende regel, hij wordt dan nog niet gelezen, dat gebeurd pas met .ReadLine() die je twee keer aanroeptquote:Op maandag 1 augustus 2011 22:46 schreef Modus het volgende:
Is dat zo? Alles wat binnen de Do While-Loop code valt gaat toch over dezelfde regel?
Ah, maar dan gebeurd er dus wel wat anders dan net! Dat is iets anders dan "nog steeds niets"quote:Heb de code aangepast zoals je aangeeft en dan gebeurt er nog steeds niks, label5 en 6 blijven leeg.
1 2 3 4 5 6 7 8 9 10 11 12 13 | Do While not objReader.EndOfStream NewTextLine = objReader.ReadLine() SplitLineArr = Split(NewTextLine, ";") Label5.Text = NewTextLine Label6.Text = SplitLineArr(0) ' Dim index As Integer = OrderListBox.FindString(SplitLineArr(0)) ' If index <> -1 Then ' OrderListBox.Items(index) = NewTextLine ' ArticlePrice = Convert.ToDecimal(Trim(SplitLineArr(2)), New System.Globalization.CultureInfo("en-US")) ' TotalPrice = TotalPrice + (Trim(SplitLineArr(3)) * ArticlePrice) ' End If Loop |
Dan is het logisch dat jouw labels leegblijven Die labels bevatten namelijk alleen de inhoud van de laatste regel (die wordt immers als laatste ingelezen in de DO-loop).quote:Op maandag 1 augustus 2011 23:10 schreef Modus het volgende:
Bij het creëren en vullen van dat tekstbestand wordt idd elke keer een enter aan het einde van een weggeschreven regel toegevoegd, heb het idee dat het daar iets mee te maken heeft ja. Als ik het open en naar het einde van het bestand ga, kom ik uit onder de tekstregels, aan het begin van een nieuwe regel.
Tijdens het wegschrijven (ik neem aan dat dat met een DO of FOR-loop gaat) zou je kunnen kijken of je met de laatste regel bezig bent en als dat het geval is, voeg je geen witregel toe.quote:Is er een manier om dat tijdens het wegschrijven al te voorkomen, of moet je iets doen waardoor je na de laatste regel de nieuwe lege regel weer delete o.i.d.? Die enter moet natuurlijk wel gebruikt worden om telkens regels onder elkaar in het textbestand te kunnen krijgen...?
Dat zal denk ik de makkelijkste optie zijn, zal vanavond eens kijken thuis. Thanks.quote:Op dinsdag 2 augustus 2011 09:54 schreef TallMan het volgende:
Of bij het uitlezen van het bestand kijken of je een lege regel hebt uitgelezen en die niet processen
|
Forum Opties | |
---|---|
Forumhop: | |
Hop naar: |