Excel Forum
ALTIN ÜYELİK Hakkında Bilgi


Geri Git   Excel Forum > EXCEL-Soruları > Makro-VBA
Atatürk
Şifremi Unuttum

DUYURU SİSTEMİ / REKLAM PANOSU

Makro-VBA Makro veya VBA ile ilgili sorularınızı buraya gönderebilirsiniz.
Dosya ekleyebilirsiniz

Özel Arama


Yanıtla
 
Paylaş Konu Araçları Görünüm Modları
Eski 22-06-2017, 16:10   #1
avare1907
Altın Üye
 
Giriş: 27/10/2016
Şehir: istanbul
Mesaj: 9
Excel Vers. ve Dili:
excel 2010 türkçe
Varsayılan Excel üzerinden otomatik mail gönderme

Merhaba arkadaşlar çok araştırdım çeşitli denemeler de yaptım fakat henüz bi sonuca ulaşamadım eğer yarcımcı olabilirseniz çok memnun olurum...Benim rutin olarak hergün firmanın kullandığı programdan aldığım güncel veriyi excel üzerine yapıştırıp bu bilgiyi sonra kopyalayıp e-mail'e yapıştırıp çoklu mail adresine gönderiyorum...bunu otomatik hale getirme şansım varmıdır...örnek dosya ekledim.kopyalanacak alan sekmesindeki çerçeveli alan kullanmak istediğim verilerin tam denk geldiği alan o alanı kopyalayıp sayfa 1'deki renkli alana yapıştırsın sonra o renkli alanı otomatik mail gönderebileyim tabii kişiler otomatik ekli hatta ve hatta mümkün ise konu başlığıda standart hazır gelsin...şimdiden teşekkürler olursa
Eklenmiş Dosyalar
Dosya Türü: xlsx ÖRNEK.xlsx (9.0 KB, 10 Görüntülenme)
avare1907 Çevrimdışı   Alıntı Yaparak Cevapla
Eski 22-06-2017, 16:52   #2
asri
Altın Üye
 
Giriş: 24/04/2005
Şehir: Istanbul
Mesaj: 2,375
Excel Vers. ve Dili:
Office 2016 TR 64 Bit
Varsayılan

Alıntı:
avare1907 tarafından gönderildi Mesajı Görüntüle
Merhaba arkadaşlar çok araştırdım çeşitli denemeler de yaptım fakat henüz bi sonuca ulaşamadım eğer yarcımcı olabilirseniz çok memnun olurum...Benim rutin olarak hergün firmanın kullandığı programdan aldığım güncel veriyi excel üzerine yapıştırıp bu bilgiyi sonra kopyalayıp e-mail'e yapıştırıp çoklu mail adresine gönderiyorum...bunu otomatik hale getirme şansım varmıdır...örnek dosya ekledim.kopyalanacak alan sekmesindeki çerçeveli alan kullanmak istediğim verilerin tam denk geldiği alan o alanı kopyalayıp sayfa 1'deki renkli alana yapıştırsın sonra o renkli alanı otomatik mail gönderebileyim tabii kişiler otomatik ekli hatta ve hatta mümkün ise konu başlığıda standart hazır gelsin...şimdiden teşekkürler olursa
Aşağıdaki şekilde deneyiniz.
"SAYFA 01" I1 de mail adresleri ; ile ayrılmış yazılmalıdır.
"SAYFA 01" I2 de mail konusu yazılmalıdır.

Maili otomatik göndermek için .send deki tırnak işaretini kaldırın.
'.send

Mail_Gonder ile gönderim sağlanır.

Kod: (Rahat kopyalayabilmeniz için tüm kodu seçmenizi sağlar)
Sub Mail_Gonder()
    Sheets("SAYFA 01").Select
    Columns("A:F").Select
    Application.CutCopyMode = False
    Selection.ClearContents
    Sheets("KOPYALANACAK ALAN").Select
    Range("A1").Select
    Range("D1:I11").Select
    Selection.Copy
    Sheets("SAYFA 01").Select
    Range("A1").Select
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
    Range("A1").Select
    Call mail_secili_alan
End Sub

Sub mail_secili_alan()
      Sheets("SAYFA 01").Select
      Dim wrdEdit
      Dim alan As Range
      
      Set alan = Range("A1:F11")
            
      Set OutApp = CreateObject("Outlook.Application")
      Set OutMail = OutApp.CreateItem(0)
      With OutMail
       .To = Cells(1, "I").Value
       .CC = ""
       .BCC = ""
       .Subject = Cells(2, "I").Value
       .Display
       
       'Maili otomatik göndermek için .send deki tırnak işaretini kaldırın.
       '.send
       .HTMLBody = RangetoHTML(alan) & .HTMLBody
       End With
      
      Set wrdEdit = Nothing
      Set OutMail = Nothing
      Set OutApp = Nothing
End Sub

Function RangetoHTML(rng As Range)
' Changed by Ron de Bruin 28-Oct-2006
' Working in Office 2000-2013
    Dim fso As Object
    Dim ts As Object
    Dim TempFile As String
    Dim TempWB As Workbook

    TempFile = Environ$("temp") & "\" & Format(Now, "dd-mm-yy h-mm-ss") & ".htm"

    'Copy the range and create a new workbook to past the data in
    rng.Copy
    Set TempWB = Workbooks.Add(1)
    With TempWB.Sheets(1)
        .Cells(1).PasteSpecial Paste:=8
        .Cells(1).PasteSpecial xlPasteValues, , False, False
        .Cells(1).PasteSpecial xlPasteFormats, , False, False
        .Cells(1).Select
        Application.CutCopyMode = False
        On Error Resume Next
        .DrawingObjects.Visible = True
        .DrawingObjects.Delete
        On Error GoTo 0
    End With

    'Publish the sheet to a htm file
    With TempWB.PublishObjects.Add( _
         SourceType:=xlSourceRange, _
         Filename:=TempFile, _
         Sheet:=TempWB.Sheets(1).Name, _
         Source:=TempWB.Sheets(1).UsedRange.Address, _
         HtmlType:=xlHtmlStatic)
        .Publish (True)
    End With

    'Read all data from the htm file into RangetoHTML
    Set fso = CreateObject("Scripting.FileSystemObject")
    Set ts = fso.GetFile(TempFile).OpenAsTextStream(1, -2)
    RangetoHTML = ts.readall
    ts.Close
    RangetoHTML = Replace(RangetoHTML, "align=center x:publishsource=", _
                          "align=left x:publishsource=")

    'Close TempWB
    TempWB.Close savechanges:=False

    'Delete the htm file we used in this function
    Kill TempFile

    Set ts = Nothing
    Set fso = Nothing
    Set TempWB = Nothing
End Function
__________________
www.asriakdeniz.com
asri Çevrimdışı   Alıntı Yaparak Cevapla
Eski 23-06-2017, 09:14   #3
avare1907
Altın Üye
 
Giriş: 27/10/2016
Şehir: istanbul
Mesaj: 9
Excel Vers. ve Dili:
excel 2010 türkçe
Varsayılan

hocam desteğiniz için çok teşekkür ederim fakat anlatırken 1 konuyu atladığımı farkettim mailin bilgi kısmına (cc) e posta adresleri eklenebilirmi mümkünse...
avare1907 Çevrimdışı   Alıntı Yaparak Cevapla
Eski 23-06-2017, 09:33   #4
Korhan Ayhan
Moderatör
 
Korhan Ayhan kullanıcısının avatarı
 
Giriş: 15/03/2005
Şehir: ANTALYA
Mesaj: 22,648
Excel Vers. ve Dili:
OFFICE 2013-2016 PRO TR
Varsayılan

Kod içinde geçen aşağıdaki satırı bulun ve dilediğiniz gibi değiştirin.

Kod: (Rahat kopyalayabilmeniz için tüm kodu seçmenizi sağlar)
.CC = ""
Örnek;

B1 ve C1 hücrelerindeki adresleri ekler.

Kod: (Rahat kopyalayabilmeniz için tüm kodu seçmenizi sağlar)
.CC = Cells(1, "B").Value & "," & Cells(1, "C").Value
__________________
.
.
.

Soru sormadan önce forumumuzun aşağıdaki
bölümlerini incelediğinizde birçok sorunuza yanıt bulabilirsiniz.


Excel Dersanesi
Uygulamalı Excel Eğitimi
Excel İçin Örnek Uygulamalar
Video Dersane (***Altın Üyelere Özel***)

Lütfen sorularınızın çözümlendiğine dair geri dönüş mesajı yazınız...!
Lütfen yazım ve forum kurallarına uyalım...!
Lütfen sorularımızı açık ve net bir dille ifade edelim...!



FORUM KURALLARI
Korhan Ayhan Çevrimdışı   Alıntı Yaparak Cevapla
Yanıtla


Konu Araçları
Görünüm Modları

Gönderme Kuralları
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is Açık
SimgelerAçık
[IMG] kodu Açık
HTML kodu Kapalı


Saat 06:02


Bu forum Elit NET - www.elitnet.com.tr tarafından sunulmaktadır.

Excel Eğitimi - Mobil Uygulama - Çorlu - Çorlu Web Tasarım - Tarot Falı - invest in turkey - Lingerie - Dyeing Machine - Karton Bardak- Çorlu Özel Eğitim- Site Yönetimi- Led Aydınlatma- Pronet Tekirdağ- Çorlu Kamera- Pronet Edirne- Pronet Kırklareli- Pronet Çerkezköy- Pronet Çorlu- Pronet Lüleburgaz- Pronet Keşan- Çorlu Araç Takip- Çorlu Su Arıtma- Boru Profil- Gebze Emlak- Beylikdüzü Temizlik- İstanbul Burun Estetiği- Bakır Sülfat- Rampa- Rotary- Çorlu İnternet Sitesi- youngblood- Çorlu Palet- Çerkezköy Palet- Çorlu Prefabrik- Çorlu Sürücü Kursu- Çorlu Sandviç Panel- Şişli Avukat- Korona Test Kalemi- Çorlu Vinç- Çorlu Pimapen Tamiri- Çorlu Çelik Konstruksiyon-
Powered by vBulletin Version 3.7.2
Copyright ©2000 - 2017, Jelsoft Enterprises Ltd.
Advertisement System V2.6 By   Branden