Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

per Excel Makro, E-Mail generieren und mit Inhalt füllen

Frage Entwicklung VB for Applications

Mitglied: Hesperus

Hesperus (Level 1) - Jetzt verbinden

06.10.2009 um 23:51 Uhr, 37093 Aufrufe, 6 Kommentare

Es soll in Excel per Makro (Button) eine E-Mail generieren und mit einem vorher definierten Bereich des Dokumentes gefüllt werden.

Guten Abend zusammen,

ich arbeite im moment an einem Excel Makro, welches "bei Klick" eine neue E-Mail (Outlook) öffnen und danach mit einem bestimmten Bereich des Excel-Dokuments füllen soll. Soweit so gut funktioniert zumindest schon einmal der Teil mit der E-Mail und der Auswahl des Bereiches nur bei dem Teil, wie ich diesen Bereich in die E-Mail bekomme, könnte ich Hilfe gebrauchen *g*.

Hier erst einmal der bisherige Code:

01.
Private Sub Bestellung_Click() 
02.
 
03.
Range("A1:H45").Select 
04.
Selection.Copy 
05.
Dim ol, mail As Object 
06.
Set ol = CreateObject("Outlook.Application") 
07.
Set mail = ol.CreateItem(0) 
08.
mail.Subject = "Bestellung " & Now 
09.
mail.To = "Max.Mustermann@test.uk" 
10.
mail.cc = "Max.Mustermann@test.uk" 
11.
'mail.bcc = "" 
12.
mail.body = "test" 
13.
 
14.
'Mail anzeigen 
15.
mail.Display 
16.
 
17.
End Sub"
Da wo im Moment "test" steht soll dann der Inhalt der Range("A1:H45") stehen, nur hat bisher keiner meiner Befehle funktioniert. Ich hoffe Ihr könnt mir hier einen Tipp geben.

Als zweites wollte ich (wenn möglich) nach versenden der E-Mail einen zweiten Bereich (Range("A7:H45")) leeren/löschen.
Ist es möglich diesen Befehl mit dem senden der E-Mail zu verknüpfen?

Habt schon mal vielen Dank für Eure Hilfe
MfG Hesperus
Mitglied: godlie
07.10.2009 um 11:41 Uhr
Hallo,

naja so einfach mit der Range geht das leider nicht.
Was dir evlt. helfen kann ist es wenn du mit VBA die Zwischenablage ausliest und diese dann einfügst in den Body der Email.
Bitte warten ..
Mitglied: Hesperus
07.10.2009 um 12:06 Uhr
Hallo godlie,

genau so hatte ich mir das Vorgestellt, nur fehlt mir dafür der ensprechende Befehl. Alles was ich bisher ausprobiert habe ist auf Fehler gelaufen.

Vielleicht kannst du mir da einen Tipp geben wie es aussehen könnte.

Vielen Dank
Hesperus
Bitte warten ..
Mitglied: 76109
07.10.2009 um 17:42 Uhr
Hallo Hesperus!

Also mit Text bekommst Du keine vernünftige Tabellenansicht hin. Aufgrund der unterschiedlichen Zeichenbreiten nützt es auch nichts, eine bestimmte Spaltenbreite mit Leerzeichen zu erzeugen.

Alternativ kannst Du mal diesen Code testen. Er erzeugt eine Tabelle im HTML-Format und funktioniert zumindest mit Outlook Express.

Die Konstanten entsprechend anpassen:
01.
Option Explicit 
02.
 
03.
Const SheetName = "Tabelle1"    'Tabellenname 
04.
 
05.
Const BegZeile = 1              'Zeile 1 
06.
Const EndZeile = 45             'Zeile 45 
07.
Const BegSpalte = 1             'Spalte A 
08.
Const EndSpalte = 8             'Spalte H 
09.
 
10.
Const DelRange = "A7:H45"       'Inhalte löschen 
11.
 
12.
Private Sub Bestellung_Click() 
13.
    Dim appMail As Object 
14.
     
15.
    Set appMail = CreateObject("Outlook.Application").CreateItem(0) 
16.
 
17.
    With appMail 
18.
        .Subject = "Bestellung " & Now 
19.
        .To = "Max.Mustermann@test.uk" 
20.
        .cc = "Max.Mustermann@test.uk" 
21.
        .HTMLbody = GetHtmlBodyText() 
22.
        .Display 
23.
    End With 
24.
    Set appMail = Nothing 
25.
End Sub 
26.
 
27.
Private Function GetHtmlBodyText() As String 
28.
    Dim Wks As Worksheet, Text As String, c As Integer, r As Integer 
29.
     
30.
    Set Wks = Sheets(SheetName) 
31.
     
32.
    Text = "<DIV>" & vbCrLf 
33.
    Text = Text & "<TABLE cellSpacing=0 cellPadding=0 width=""100%"" border=1>" & vbCrLf 
34.
    Text = Text & "<TBODY>" & vbCrLf 
35.
     
36.
    For r = BegZeile To EndZeile 
37.
        Text = Text & "<TR>" & vbCrLf 
38.
        For c = BegSpalte To EndSpalte 
39.
            Text = Text & "<TD>" & Wks.Cells(r, c) & "</TD>" & vbCrLf 
40.
        Next 
41.
        Text = Text & "</TR>" & vbCrLf 
42.
    Next 
43.
     
44.
    Text = Text & "</TBODY></TABLE></DIV>" & vbCrLf 
45.
     
46.
    'Löschen (Formate bleiben erhalten) 
47.
    'Wks.Range(DelRange).ClearContents 
48.
     
49.
    GetHtmlBodyText = Text 
50.
End Function
Gruß Dieter
Bitte warten ..
Mitglied: Hesperus
09.10.2009 um 08:00 Uhr
Hallo Dieter,

der Code funktioniert genau so wie ich mir das vorgestellt habe. Hab vielen Dank für deine Hilfe.

Schönes WE
LG Hesperus
Bitte warten ..
Mitglied: 76109
09.10.2009 um 09:29 Uhr
Hallo Hesperus!

Freut mich zu hören, dass es nach Deinen Wünschen funktioniert

Falls Du die Tabellenansicht etwas verschönern möchtest, dann ändere mal in Zeile 33 die Werte für "cellSpacing=0" z.B. in 1, 2.

Auch Dir ein schönes WE

Gruß Dieter
Bitte warten ..
Mitglied: togreiner
11.02.2011 um 09:40 Uhr
Hallo,
gibt es diese Exceldatei final ? Ich brauch dringend etwas ähnliches, habe aber keine Kenntnisse in der Programierung

t.
Bitte warten ..
Ähnliche Inhalte
Microsoft Office
VBA Makro Mails aus Excel versenden
gelöst Frage von ExxiStMicrosoft Office7 Kommentare

Guten Tag zusammen, folgendes Problem treibt mich schon seit Tagen zur Verzweiflung: Aus einer Excel Datei werden durch folgendes ...

Microsoft Office
Excel 2010 Zellen mit bestimmten Inhalt mit Makro formartierten
gelöst Frage von packmann2016Microsoft Office5 Kommentare

ich möchte mit Hilfe einem Makro Zellen die einen bestimmten Inhalt ("G" und "A") haben ausblenden. Versuchte mit dem ...

E-Mail
Gefälschte E-Mail-Inhalte mit anderen Kontoinformationen
gelöst Frage von lasterE-Mail17 Kommentare

Hallo, habe diese Woche von zwei Firmen gehört, die das gleiche Problem haben - sie bekommen kein Geld von ...

E-Mail
E-Mail Archivieren - Externe Inhalte
Frage von leon123E-Mail1 Kommentar

Hallo zusammen, wie würdet Ihr beim E-Mail Archivieren mit externen Inhalten umgehen, wenn ich diese als HTML speichern will. ...

Neue Wissensbeiträge
Windows 10

Autsch: Microsoft bündelt Windows 10 mit unsicherer Passwort-Manager-App

Tipp von kgborn vor 1 TagWindows 102 Kommentare

Unter Microsofts Windows 10 haben Endbenutzer keine Kontrolle mehr, was Microsoft an Apps auf dem Betriebssystem installiert (die Windows ...

Sicherheits-Tools

Achtung: Sicherheitslücke im FortiClient VPN-Client

Tipp von kgborn vor 1 TagSicherheits-Tools

Ich weiß nicht, wie häufig die NextGeneration Endpoint Protection-Lösung von Fortinet in deutschen Unternehmen eingesetzt wird. An dieser Stelle ...

Internet

USA: Die FCC schaff die Netzneutralität ab

Information von Frank vor 1 TagInternet4 Kommentare

Jetzt beschädigt US-Präsident Donald Trump auch noch das Internet. Der neu eingesetzte FCC-Chef Ajit Pai ist bekannter Gegner einer ...

DSL, VDSL

ALL-BM200VDSL2V - Neues VDSL-Modem mit Vectoring von Allnet

Information von Lochkartenstanzer vor 1 TagDSL, VDSL2 Kommentare

Moin, Falls jemand eine Alternative zu dem draytek sucht: Gruß lks

Heiß diskutierte Inhalte
Windows Server
GPO nur für bestimmte Computer
Frage von Leo-leWindows Server13 Kommentare

Hallo Forum, gern würde ich ein Robocopy script per Bat an eine GPO hängen. Wichtig wäre aber dort der ...

Windows Server
KMS Facts for Client configuration
Frage von winlinWindows Server13 Kommentare

Hey Leute, wir haben in unserem Netz nun einen neuen KMS Server. Haben Bestands-VMs die noch nicht aktiviert sind. ...

Router & Routing
OpenWRT bzw. L.E.D.E auf Buffalo WZR-HP-AG300H - update
gelöst Frage von EpigeneseRouter & Routing11 Kommentare

Guten Tag, ich habe auf einem Buffalo WZR-HP-AG300H die alternative Firmware vom L.E.D.E Projekt geflasht. Ich bin es von ...

Windows Tools
Software-Tool zum Entfernen von bösartigem Windows
Frage von emeriksWindows Tools11 Kommentare

Hi, siehe Betreff hat das jemals irgendjemand schonmal sinnvoll eingesetzt? (MRT) E.