PSD-Tutorials.de
Forum für Design, Fotografie & Bildbearbeitung
Tutkit
Agentur
Hilfe
Kontakt
Start
Forum
Aktuelles
Besonderer Inhalt
Foren durchsuchen
Tutorials
News
Anmelden
Kostenlos registrieren
Aktuelles
Suche
Suche
Nur Titel durchsuchen
Von:
Menü
Anmelden
Kostenlos registrieren
App installieren
Installieren
JavaScript ist deaktiviert. Für eine bessere Darstellung aktiviere bitte JavaScript in deinem Browser, bevor du fortfährst.
Du verwendest einen veralteten Browser. Es ist möglich, dass diese oder andere Websites nicht korrekt angezeigt werden.
Du solltest ein Upgrade durchführen oder einen
alternativen Browser
verwenden.
Antworten auf deine Fragen:
Neues Thema erstellen
Start
Forum
Sonstiges
Office, Software, Hardware, Technische Fragen
Microsoft Excel, Google Sheets
Per Button: Teile eines Arbeitsblattes als neues Arbeitsblatt speichern?
Beitrag
<blockquote data-quote="AranankA" data-source="post: 2678293" data-attributes="member: 639133"><p>Danke für die Mühe! Ich war auch mal aktiv und hatte durch den Makro Tipp motiviert (unabhängig von der Anfrage hier), probiert wie weit ich komme:</p><p>[code]</p><p>Option Explicit</p><p>Sub arbeitsblatt_erstellen()</p><p></p><p>Dim strName As String</p><p>Dim wsNew As Object</p><p></p><p>strName = Sheets("Zeiterfassung").Range("B7").Value</p><p></p><p>On Error Resume Next</p><p></p><p> Application.ScreenUpdating = False</p><p> ' Prüfung, ob Arbeitsblatt schon vorhanden ist.</p><p> ' Wenn ja: löschen und neu erstellen, wenn nein; erstellen:</p><p> For Each wsNew In ActiveWorkbook.Sheets</p><p> If wsNew.Name = strName Then</p><p> Sheets(wsNew.Name).Delete</p><p> Set wsNew = Worksheets.Add</p><p> wsNew.Name = strName</p><p> ' Neues Blatt hinten anfügen:</p><p> ActiveSheet.Move After:=Sheets(ActiveWorkbook.Sheets.Count)</p><p> Else</p><p> Set wsNew = Worksheets.Add</p><p> wsNew.Name = strName</p><p> ActiveSheet.Move After:=Sheets(ActiveWorkbook.Sheets.Count)</p><p> End If</p><p> Next wsNew</p><p> </p><p> Sheets("Zeiterfassung").Select</p><p> Range("A1:G41").Select</p><p> Selection.Copy</p><p> Sheets(strName).Select</p><p> </p><p> 'Einfügen ohne Formeln, mit Formatierung:</p><p> Range("A1").PasteSpecial xlPasteValuesAndNumberFormats</p><p> Sheets("Zeiterfassung").Select</p><p> ActiveSheet.Range("A1").Select</p><p> </p><p> 'Deselektieren der C&P Felder:</p><p> Application.CutCopyMode = False</p><p> </p><p> Application.ScreenUpdating = True</p><p> </p><p>End Sub</p><p></p><p>[/code]</p><p></p><p>Klappt auch einwandfrei... ...mit einer winzigen Einschränkung: nach dem Kopiervorgang habe ich, zusätzlich zu den 3 vorhandenen, 3 leere Tabellen zusätzlich.</p><p></p><p><strong>P.S.:</strong> Ich korrigiere: Klappt auch einwandfrei... ...mit einer winzigen Einschränkung: nach <em>jedem </em>Kopiervorgang habe ich, zusätzlich zu den vorhandenen Tabellen, <em>Anzahl vorhandene Tabellen - 1 leere Tabellen</em> mit vorlaufender Nummerierung ("Tabelle 123", "Tabelle 124", usw.) zusätzlich.</p></blockquote><p></p>
[QUOTE="AranankA, post: 2678293, member: 639133"] Danke für die Mühe! Ich war auch mal aktiv und hatte durch den Makro Tipp motiviert (unabhängig von der Anfrage hier), probiert wie weit ich komme: [code] Option Explicit Sub arbeitsblatt_erstellen() Dim strName As String Dim wsNew As Object strName = Sheets("Zeiterfassung").Range("B7").Value On Error Resume Next Application.ScreenUpdating = False ' Prüfung, ob Arbeitsblatt schon vorhanden ist. ' Wenn ja: löschen und neu erstellen, wenn nein; erstellen: For Each wsNew In ActiveWorkbook.Sheets If wsNew.Name = strName Then Sheets(wsNew.Name).Delete Set wsNew = Worksheets.Add wsNew.Name = strName ' Neues Blatt hinten anfügen: ActiveSheet.Move After:=Sheets(ActiveWorkbook.Sheets.Count) Else Set wsNew = Worksheets.Add wsNew.Name = strName ActiveSheet.Move After:=Sheets(ActiveWorkbook.Sheets.Count) End If Next wsNew Sheets("Zeiterfassung").Select Range("A1:G41").Select Selection.Copy Sheets(strName).Select 'Einfügen ohne Formeln, mit Formatierung: Range("A1").PasteSpecial xlPasteValuesAndNumberFormats Sheets("Zeiterfassung").Select ActiveSheet.Range("A1").Select 'Deselektieren der C&P Felder: Application.CutCopyMode = False Application.ScreenUpdating = True End Sub [/code] Klappt auch einwandfrei... ...mit einer winzigen Einschränkung: nach dem Kopiervorgang habe ich, zusätzlich zu den 3 vorhandenen, 3 leere Tabellen zusätzlich. [B]P.S.:[/B] Ich korrigiere: Klappt auch einwandfrei... ...mit einer winzigen Einschränkung: nach [I]jedem [/I]Kopiervorgang habe ich, zusätzlich zu den vorhandenen Tabellen, [I]Anzahl vorhandene Tabellen - 1 leere Tabellen[/I] mit vorlaufender Nummerierung ("Tabelle 123", "Tabelle 124", usw.) zusätzlich. [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ★ = 12, ◇ = 4 und die Hälfte von ★ zu ◇ addiert wird, was ist das Ergebnis?
Antworten
Start
Forum
Sonstiges
Office, Software, Hardware, Technische Fragen
Microsoft Excel, Google Sheets
Per Button: Teile eines Arbeitsblattes als neues Arbeitsblatt speichern?
Oben