Registriert seit: 14.04.2014
Version(en): 2003, 2007
Hallo, mein Code macht das, was Du haben möchtest. Die andere Seite sollte nur als ergänzende Info dienen. Unten jetzt ein erweiterter Code. Die Arbeitsweise sollte anhand der im Code enthaltenen Kommentare verständlich sein. Code: Sub von_links_loeschen() Dim lngZ As Long, i As Long lngZ = Cells(Rows.Count, 1).End(xlUp).Row 'letzte belegte Zelle in Spalte 1 Application.ScreenUpdating = False Columns(2).Clear 'Spalte 2 leeren zum Übertragen der abgeschnittenen Werte 'ab Zeile 2 werden die Inhalte der Zellen in Spalte A bis zum letzten "/" abgeschnitten 'und der Rest wird in Spalte zwei geschrieben For i = 2 To lngZ Cells(i, 2).Value = Mid(Cells(i, 1).Value, InStrRev(Cells(i, 1).Value, "/") + 1) Next i Application.ScreenUpdating = True End Sub
Gruß Atilla
Folgende(r) 1 Nutzer sagt Danke an atilla für diesen Beitrag:1 Nutzer sagt Danke an atilla für diesen Beitrag 28
• TheHydrogena
Registriert seit: 05.02.2018
Version(en): MSOffice 2007
(31.03.2018, 08:17)shift-del schrieb: Du hast drei konkrete Beispiele genannt. Bei allen funktionieren die Formeln. Oh sorry, dann habe ich nicht genau hin geguckt. Aber wie schon beschrieben, wenn der Fall vorkommt reicht es ja nicht die ersten 5 Zeichen zu löschen Code: /6/8/0/684-301-4.jpg
Deshalb fand ich den Ansatz mit dem von rechts gehend das erste "/" zu suchen ja so interessant, weiß aber nicht wie man den Wert dann Weiterverarbeiten kann, momentan löscht er ihn ja nur, so dass am Ende da steht Gruß
Registriert seit: 10.04.2014
Version(en): Microsoft 365, mtl. Kanal
Hi, verstehe ich dich richtig? Arbeitsblatt mit dem Namen 'Tabelle2' | | A | B | 1 | 6/8/0/684-301-4.jpg | 684-301-4.jpg | 2 | A-55/6/8/0/A55-12345-B.jpg | A55-12345-B.jpg |
Zelle | Formel | B1 | {=TEIL(A1;MAX(WENN(TEIL(A1;SPALTE(1:1);1)="/";SPALTE(1:1)))+1;55)} |
Achtung, Matrixformel enthalten! | Die geschweiften Klammern{} werden nicht eingegeben. | Verlassen Sie den Zelleneditor mit Strg+Shift + Enter, statt Enter alleine. |
Verwendete Systemkomponenten: [Windows (32-bit) NT :.00] MS Excel 2013 | Diese Tabelle wurde mit Tab2Html (v2.6.0) erstellt. ©Gerd alias Bamberg |
aus: http://www.office-loesung.de/ftopic340146_0_0_asc.php
Gruß Günter Jeder Fehler erscheint unglaublich dumm, wenn andere ihn begehen. angebl. von Georg Christoph Lichtenberg (1742-1799)
Registriert seit: 12.04.2014
Version(en): Office 365
Oder ohne CSE: Code: =TEIL(A2;SUCHEN("#";WECHSELN(A2;"/";"#";3))+1;999)
Wir sehen uns! ... Detlef
Meine Beiträge können Ironie oder Sarkasmus enthalten.
Registriert seit: 10.04.2014
Version(en): Office 2019
Hallo Günter, dann ginge auch (ohne CSE-Abschluss) PHP-Code: =ERSETZEN(A1;1;VERWEIS(9^9;FINDEN("/";A1;SPALTE(1:1)));"")
Gruß Jörg stolzes Mitglied im ----Excel-Verein Freund einer excellenten Power Query-Abfrage
Registriert seit: 10.04.2014
Version(en): Office 2019
(31.03.2018, 18:03)shift-del schrieb: Oder ohne CSE:
Code: =TEIL(A2;SUCHEN("#";WECHSELN(A2;"/";"#";3))+1;999)
Hallo Detlef, aber hier nicht zutreffend für A2..: Arbeitsblatt mit dem Namen 'Blatt2' | | A | B | C | D | 1 | 6/8/0/684-301-4.jpg | 684-301-4.jpg | 684-301-4.jpg | 684-301-4.jpg | 2 | A-55/6/8/0/A55-12345-B.jpg | A55-12345-B.jpg | A55-12345-B.jpg | 0/A55-12345-B.jpg |
Zelle | Formel | B1 | {=TEIL(A1;MAX(WENN(TEIL(A1;SPALTE(1:1);1)="/";SPALTE(1:1)))+1;55)} | C1 | =ERSETZEN(A1;1;VERWEIS(9^9;FINDEN("/";A1;SPALTE(1:1)));"") | D1 | =TEIL(A1;SUCHEN("#";WECHSELN(A1;"/";"#";3))+1;999) |
Achtung, Matrixformel enthalten! | Die geschweiften Klammern{} werden nicht eingegeben. | Verlassen Sie den Zelleneditor mit Strg+Shift + Enter, statt Enter alleine. |
Verwendete Systemkomponenten: [Windows (32-bit) NT 6.01] MS Excel 2010 | Diese Tabelle wurde mit Tab2Html (v2.6.0) erstellt. ©Gerd alias Bamberg |
Gruß Jörg stolzes Mitglied im ----Excel-Verein Freund einer excellenten Power Query-Abfrage
Registriert seit: 12.04.2014
Version(en): Office 365
Dann noch etwas länger: Code: =TEIL(A2;SUCHEN("#";WECHSELN(A2;"/";"#";LÄNGE(A2)-LÄNGE(WECHSELN(A2;"/";""))))+1;999)
Wir sehen uns! ... Detlef
Meine Beiträge können Ironie oder Sarkasmus enthalten.
Registriert seit: 14.04.2014
Version(en): 2003, 2007
(31.03.2018, 17:16)TheHydrogena schrieb: Deshalb fand ich den Ansatz mit dem von rechts gehend das erste "/" zu suchen ja so interessant, weiß aber nicht wie man den Wert dann Weiterverarbeiten kann, momentan löscht er ihn ja nur, so dass am Ende
Gruß Hallo, liest Du hier die Beiträge auch?
Gruß Atilla
Folgende(r) 1 Nutzer sagt Danke an atilla für diesen Beitrag:1 Nutzer sagt Danke an atilla für diesen Beitrag 28
• TheHydrogena
Registriert seit: 10.04.2014
Version(en): Office 2019
(31.03.2018, 18:52)shift-del schrieb: Dann noch etwas länger... Hi, muss doch aber nicht, oder ..?
Gruß Jörg stolzes Mitglied im ----Excel-Verein Freund einer excellenten Power Query-Abfrage
Registriert seit: 05.02.2018
Version(en): MSOffice 2007
01.04.2018, 05:51
(31.03.2018, 08:51)atilla schrieb: Hallo,
mein Code macht das, was Du haben möchtest. Die andere Seite sollte nur als ergänzende Info dienen.
Unten jetzt ein erweiterter Code. Die Arbeitsweise sollte anhand der im Code enthaltenen Kommentare verständlich sein.
Code: Sub von_links_loeschen() Dim lngZ As Long, i As Long lngZ = Cells(Rows.Count, 1).End(xlUp).Row 'letzte belegte Zelle in Spalte 1 Application.ScreenUpdating = False Columns(2).Clear 'Spalte 2 leeren zum Übertragen der abgeschnittenen Werte 'ab Zeile 2 werden die Inhalte der Zellen in Spalte A bis zum letzten "/" abgeschnitten 'und der Rest wird in Spalte zwei geschrieben For i = 2 To lngZ Cells(i, 2).Value = Mid(Cells(i, 1).Value, InStrRev(Cells(i, 1).Value, "/") + 1) Next i Application.ScreenUpdating = True End Sub
Sorry ja , bin das nur überflogen und auf die Nachrichten eingegangen, hatte keine Zeit das ganze zu Überprüfen. Hab das grade aber getestet und die Idee hat aber super geklappt. Damit wäre mein anliegen soweit erledigt bzw. wurde sehr gut beantwortet, Danke dafür :D Gruß
|