Thema Datum  Von Nutzer Rating
Antwort
05.04.2014 16:38:19 Mat
NotSolved
05.04.2014 18:11:57 gabi
NotSolved
05.04.2014 18:22:24 Gast34946
NotSolved
05.04.2014 18:32:08 gabi
NotSolved
06.04.2014 14:42:32 Gast55544
NotSolved
06.04.2014 14:49:19 Gast19483
NotSolved
06.04.2014 15:37:43 Mat
NotSolved
06.04.2014 16:37:39 Gast75123
NotSolved
06.04.2014 17:30:21 gabi
NotSolved
Blau Excel VBA Zellen von A nach B kopieren, mehrere Möglichkeiten, IF THEN ELSEIF
06.04.2014 17:11:32 Gast80865
NotSolved
06.04.2014 22:55:45 Mat
NotSolved

Ansicht des Beitrags:
Von:
Gast80865
Datum:
06.04.2014 17:11:32
Views:
1720
Rating: Antwort:
  Ja
Thema:
Excel VBA Zellen von A nach B kopieren, mehrere Möglichkeiten, IF THEN ELSEIF

Hallo Mat,

 

also bei mir läuft der Code einwandfrei – ohne "Runtime Error 424 - object required" bzw. seiner deutschen Übersetzung. Allerdings musst ich dazu auch den Tabellen – Codename in "Content_Calendar" bzw.  "Posts_ORIGINAL" ändern !  Und den Codenamen legst du doch im VBA Editor-Eigenschaftsfenster fest ! ? !

 

Der Blattname in der Blattregisterkarte (unten) ist jedoch "Tabellenname", d.h. der Code muss das

Objekt "Tabelle" (Worksheet) so ansprechen :

 

If Sheets("Content_Calendar").Range("C12") = "ORI1_" Then

        Sheets("Posts_ORIGINAL").Activate

        Sheets("Posts_ORIGINAL").Range("C10:F22").Copy

        Sheets("Content_Calendar").Activate

        Sheets("Content_Calendar").Range("C13").Select

        ActiveSheet.Paste

 

Else

        Sheets("Data").Range("J7").Copy

        Sheets("Content_Calendar").Activate

        Sheets("Content_Calendar").Range("D19").Select

        ActiveSheet.Paste

        Application.CutCopyMode = False

 

 

Last.not.Least deine Code etwas übersichtlicher – und Tschüss (gabi)

 

Sub mDay_1()
Dim s As String
Dim WennBereich As Range, VonBereich As Range, NachBereich As Range

      s = ActiveCell.Value    'wozu auch immer
      
      Set WennBereich = Sheets("Content_Calendar").Range("C12")
      Set NachBereich = Sheets("Content_Calendar").Range("C13")
      
      Select Case WennBereich.Value
        Case "ORI1_"
          Set VonBereich = Sheets("Posts_ORIGINAL").Range("C10:F22")
        Case "ORI2_"
          Set VonBereich = Sheets("Posts_ORIGINAL").Range("P10:S22")
        Case "ORI3_"
          Set VonBereich = Sheets("Posts_ORIGINAL").Range("C29:F41")
        Case "ORI4_"
          Set VonBereich = Sheets("Posts_ORIGINAL").Range("P29:S41")
        'usw.
        '
      End Select
      
      Application.ScreenUpdating = False  'guck VBA Hilfe
      
      If Not VonBereich Is Nothing Then
        'd.h. im Select wurde ein Wert gefunden
        VonBereich.Copy Destination:=NachBereich
      Else
        'd.h. nichts gefunden
        Sheets("Data").Range("J7").Copy Destination:= _
          Sheets("Content_Calendar").Range("D19")
      End If
      '
      Sheets("Content_Calendar").Activate
      Application.ScreenUpdating = True
      '
End Sub

 

 

PS:  das zum vorletzen Beitrag – LOL

 

 


Ihre Antwort
  • Bitte beschreiben Sie Ihr Problem möglichst ausführlich. (Wichtige Info z.B.: Office Version, Betriebssystem, Wo genau kommen Sie nicht weiter)
  • Bitte helfen Sie ebenfalls wenn Ihnen geholfen werden konnte und markieren Sie Ihre Anfrage als erledigt (Klick auf Häckchen)
  • Bei Crossposting, entsprechende Links auf andere Forenbeiträge beifügen / nachtragen
  • Codeschnipsel am besten über den Code-Button im Text-Editor einfügen
  • Die Angabe der Emailadresse ist freiwillig und wird nur verwendet, um Sie bei Antworten auf Ihren Beitrag zu benachrichtigen
Thema: Name: Email:



  • Bitte beschreiben Sie Ihr Problem möglichst ausführlich. (Wichtige Info z.B.: Office Version, Betriebssystem, Wo genau kommen Sie nicht weiter)
  • Bitte helfen Sie ebenfalls wenn Ihnen geholfen werden konnte und markieren Sie Ihre Anfrage als erledigt (Klick auf Häckchen)
  • Bei Crossposting, entsprechende Links auf andere Forenbeiträge beifügen / nachtragen
  • Codeschnipsel am besten über den Code-Button im Text-Editor einfügen
  • Die Angabe der Emailadresse ist freiwillig und wird nur verwendet, um Sie bei Antworten auf Ihren Beitrag zu benachrichtigen