🙏 Helfen Sie jetzt mit, unser LibreOffice Forum zu erhalten! 🙏
Mit Ihrer Spende sichern Sie den Fortbestand, den Ausbau und die laufenden Kosten dieses Forums. 🌱

🍀 Jeder Beitrag zählt – vielen Dank für Ihre Unterstützung!🍀

❤️ DANKE >> << DANKE ❤️

>> Dank Ihrer Unterstützung -> Keine Werbung für alle registrierten LibreOffice-Forum User! <<
🤗 Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet. 🤗

Zellinhalt teilen

CALC ist die Tabellenkalkulation, die Sie immer wollten.
Antworten
Aehzebaer
Beiträge: 100
Registriert: Mo 3. Sep 2012, 08:22

Zellinhalt teilen

Beitrag von Aehzebaer » Di 21. Jan 2014, 14:42

Hallo,

ich habe Zellinhalte wo ich eine Artikelnummer bestehend aus Buchstaben und Zahlen (keine Leerzeichen!) trennen muss:

abc123
derfg789544
ztrf01645

Die Trennung erfolgt mit der ersten Zahl. Die Zahl soll als Text (also mit führender Null) dargestellt werden.

Nach der Trennung sollen Buchstaben und Zahl in zwei verschiedenen Zellen stehen:
abc 123
derfg 789544
ztrf 01645

Wie kann ich das hinbekommen?
Grüsse
Aehzebaer

Windows 10 Home x64, 11 Pro x64, LibreOffice (immer aktuellste Version)

bst
Beiträge: 35
Registriert: Mi 25. Apr 2012, 13:40
Wohnort: Ilsfeld

Re: Zellinhalt teilen

Beitrag von bst » Di 21. Jan 2014, 15:01

Hi,

mal ein Versuch. Trennt die Werte aus Spalte A und schreibt das nach B und C.

HTH, Bernd
--

Code: Alles auswählen

REM  *****  BASIC  *****

Sub Main
	dim oSheet as Object
	dim i as Long, iMax as Long
	dim ar
		
	oSheet = ThisComponent.currentController.ActiveSheet
	iMax = getLastRowInColumn(oSheet, 0) ' 0 = A, 1 = B, 2 = C
	for i = 0 to iMax
		ar = mySplit(oSheet.getCellByPosition(0, i).String)
		oSheet.getCellByPosition(1, i).string = ar(0)
		oSheet.getCellByPosition(2, i).string = ar(1)
	next	 
End Sub

Function getLastRowInColumn(oSheet as Object, iColumn as integer) as Long
	dim oUsedCells as Object
	
	oUsedCells = oSheet.Columns(iColumn).queryContentCells(23)
	getLastRowInColumn = oUsedCells.RangeAddresses(oUsedCells.Count-1).endRow
End Function

Function mySplit(strVal as string) as Variant
	dim ar(0 to 1)
   	dim i as Long
   
   	for i = 1 to len(strVal)
		if mid(strVal, i, 1) Like "#" then exit for	   	
   	Next
   	ar(0) = left(strVal, i-1)
   	ar(1) = mid(strVal, i)
   	
   	mySplit = ar
End Function   

Benutzeravatar
karolus
* LO-Experte *
Beiträge: 2533
Registriert: Fr 10. Dez 2010, 10:01

Re: Zellinhalt teilen

Beitrag von karolus » Di 21. Jan 2014, 15:27

Hallo
zuerst:
  • →Bearbeiten→Suchen und ersetzen
    suche nach
    \d+$
    ersetze durch
    |$0
    mit der Option: regulärer Ausdruck
    →→ersetze alle
Danach markiere die ganze Spalte und gehe zu:
  • →Daten→Text in Spalten
    wähle als Trennzeichen [x]sonstige |
    und stelle in der Vorschau die rechte Spalte um, von 'Standard' auf 'Text'
Karolus
LO7.4.7.5 debian 12(bookworm) auf Raspberry4b 8GB (64bit)
LO24.8.0.3 flatpak debian 12(bookworm) auf Raspberry4b 8GB (64bit)

Aehzebaer
Beiträge: 100
Registriert: Mo 3. Sep 2012, 08:22

Re: Zellinhalt teilen

Beitrag von Aehzebaer » Di 21. Jan 2014, 16:18

@bst und karolus:

funktioniert beides. Problem gelöst.

Vielen Dank für Eure Arbeit!
Grüsse
Aehzebaer

Windows 10 Home x64, 11 Pro x64, LibreOffice (immer aktuellste Version)


An alle, die das LibreOffice-Forum gern nutzen und unterstützen wollen:


Bitte helfen Sie uns mit 7 Euro pro Monat.
Durch Ihren Beitrag tragen Sie dazu bei, unsere laufenden Kosten für die kommenden Monate zu decken.
Unkompliziert per Kreditkarte oder PayPal.
Als ein kleines Dankeschön werden Sie im LO-Forum als SUPPORTER gekennzeichnet.



Antworten