Hoppa till huvudinnehåll

Hur byter jag namn på och sparar bilagor till e-postmeddelandet i en mapp i Outlook?

I Outlook kan du vanligtvis få meddelanden med bilagor, och försöker du byta namn på bifogade filer i meddelandet och spara dem i en mapp enligt nedanstående skärmdump? Uppenbarligen kan du spara dem i en mapp och byta namn på dem en efter en, men faktiskt har jag en VBA-kod kan snabbt byta namn på alla bilagor med samma namn och sedan spara i en mapp.
doc byta namn spara bifoga 1

Byt namn på och spara bilagor med samma namn i en mapp

Byt namn på och spara bilagor i en mapp med Kutools för Outlook


Svarsmeddelande med originalbilagor i Outlook

Som vi alla vet kommer de bifogade bilagorna att tas bort från det ursprungliga meddelandet när du svarar ett meddelande till mottagaren i Outlook. Om du vill svara på massage med att hålla bilagor kan du prova Kutools för Outlook's Svara med bilaga funktion, kan den svara på ett meddelande med originalbilagorna, fungerar också för alla messafe.    Klicka för alla funktioner 60 dagars gratis provperiod!
 
doc svar med bifoga
 
Kutools for Outlook: med dussintals praktiska Outlook-tillägg, gratis att prova utan begränsning på 60 dagar.
Office-fliken - Aktivera flikredigering och surfning i Microsoft Office, vilket gör arbetet enkelt
Kutools för Outlook - Boosta Outlook med 100+ avancerade funktioner för överlägsen effektivitet
Förbättra din Outlook 2021 - 2010 eller Outlook 365 med dessa avancerade funktioner. Njut av en omfattande 60-dagars gratis provperiod och höj din e-postupplevelse!

Byt namn på och spara bilagor med samma namn i en mapp

1. Välj meddelandet som du vill spara bilagorna och byta namn till samma namn.

2. Tryck Alt + F11 keys, sedan i Project1 dubbelklicka ThisOutlookSession för att skapa ett nytt tomt skript i högra avsnittet, kopiera och klistra in koden i den.

VBA: Byt namn på och spara bilagor

Public Sub SaveAttachsToDisk()
'UpdatebyExtendoffice20180521
Dim xItem As Object  'Outlook.MailItem
Dim xSelection As Selection
Dim xAttachment As Outlook.Attachment
Dim xFldObj As Object
Dim xSaveFolder As String
Dim xFSO As Scripting.FileSystemObject
Dim xFile As File
Dim xFilePath As String
Dim xNewName, xTmpName As String
Dim xExt As String
Dim xCount As Integer
On Error Resume Next
Set xFldObj = CreateObject("Shell.Application").browseforfolder(0, "Select a Folder", 0, 16)
Set xFSO = New Scripting.FileSystemObject
If xFldObj Is Nothing Then Exit Sub
xSaveFolder = xFldObj.Items.Item.Path & "\"
Set xSelection = Outlook.Application.ActiveExplorer.Selection
xNewName = InputBox("Attachment Name:", "Kutools for Outlook", xNewName)
If Len(Trim(xNewName)) = 0 Then Exit Sub
For Each xItem In xSelection
    For Each xAttachment In xItem.Attachments
        xFilePath = xSaveFolder & xAttachment.FileName
        xAttachment.SaveAsFile xFilePath
        Set xFile = xFSO.GetFile(xFilePath)
        xCount = 1
        Saved = False
        xExt = "." & xFSO.GetExtensionName(xFilePath)
        xTmpName = xNewName
        xNewName = xTmpName & xExt
        If xFSO.FileExists(xSaveFolder & xNewName) = False Then
            xFile.Name = xNewName
            xNewName = xTmpName
        Else
            xTmpName = Left(xNewName, Len(xNewName) - Len(xExt))
            While Saved = False
                xNewName = xTmpName & xCount & xExt
                If xFSO.FileExists(xSaveFolder & xNewName) = False Then
                    xFile.Name = xNewName
                    xNewName = xTmpName
                    Saved = True
                Else
                    xCount = xCount + 1
                End If
            Wend
        End If
    Next
Next
Set xFSO = Nothing
End Sub

doc byta namn på spara bilagor i en mapp 2

3. klick verktyg > Referensprojekt, i poppdialogrutan, kontrollera Microsoft Script Runtime kryssrutan.

doc byta namn på spara bilagor i en mapp 3 doc pil till höger doc byta namn på spara bilagor i en mapp 4

4. klick OK, Tryck F5 nyckel för att köra koden, a Bläddra för mapp dialogrutan dyker upp för att välja eller skapa en mapp för att placera bilagor.
doc byta namn på spara bilagor i en mapp 5

5. klick OK, ge sedan ett namn på bilagorna.
doc byta namn på spara bilagor i en mapp 6

6. klick OK, nu byts namn på bilagorna med samma namn. Om det finns dubbletter kommer de dubbletterna att läggas till nummer som suffixet.


Byt namn på och spara bilagor i en mapp med Kutools för Outlook

Egentligen finns det en funktion i Kutools för Outlook - ett praktiskt tilläggsverktyg i Outlook kan byta namn på alla bilagor innan de sparas eller skickas.

Kutools for Outlook , Inkluderar  kraftfulla funktioner och verktyg för Microsoft Outlook 2016, 2013, 2010 och Office 365.

Gratis installation Kutools för Outlook och gör sedan nedanstående steg:

1. Aktivera e-postmeddelandet i den nagativa rutan eller i meddelandefältet som du vill, klicka på Kutools > TillbehörsverktygByt namn på alla.
doc byta namn spara bifoga 2

2. I poppdialogen skriver du det nya namnet du använder för varje bilaga. Klick OKhar bilagorna bytt namn med nya namn.
doc byta namn spara bifoga 3 

3. Högerklicka på en bilaga, välj Spara alla bilagor, Klicka OK och välj en mapp för att spara bilagorna efter behov. Sedan har de bytte namn på bilagor sparats i en mapp.
doc byta namn spara bifoga 5 
doc byta namn spara bifoga 5


Bästa kontorsproduktivitetsverktyg

Kutools för Outlook - Över 100 kraftfulla funktioner för att överladda din Outlook

🤖 AI Mail Assistant: Instant proffs-e-postmeddelanden med AI-magi – ett klick för geniala svar, perfekt ton, flerspråkig behärskning. Förvandla e-post utan ansträngning! ...

📧 Email Automation: Frånvaro (tillgänglig för POP och IMAP)  /  Schemalägg Skicka e-post  /  Auto CC/BCC enligt regler när du skickar e-post  /  Automatisk vidarebefordran (avancerade regler)   /  Lägg automatiskt till hälsning   /  Dela automatiskt e-postmeddelanden med flera mottagare i individuella meddelanden ...

📨 Email Management: Hämta enkelt e-postmeddelanden  /  Blockera bluff-e-postmeddelanden av ämnen och andra  /  Ta bort duplicerade e-postmeddelanden  /  Avancerad Sökning  /  Konsolidera mappar ...

📁 Bilagor ProBatch Spara  /  Batch lossa  /  Batchkomprimera  /  Automatisk sparning   /  Auto Lossa  /  Automatisk komprimering ...

🌟 Gränssnittsmagi: 😊 Fler vackra och coola emojis   /  Öka din Outlook-produktivitet med flikar  /  Minimera Outlook istället för att stänga ...

👍 Underverk med ett klick: Svara alla med inkommande bilagor  /   E-postmeddelanden mot nätfiske  /  🕘Visa avsändarens tidszon ...

👩🏼‍🤝‍👩🏻 Kontakter och kalender: Lägg till kontakter i grupp från valda e-postmeddelanden  /  Dela upp en kontaktgrupp till individuella grupper  /  Ta bort påminnelser om födelsedag ...

Över 100 funktioner Vänta på din utforskning! Klicka här för att upptäcka mer.

Läs mer       Gratis nedladdning      Inköp
 

 

Comments (4)
No ratings yet. Be the first to rate!
This comment was minimized by the moderator on the site
Thanks, it is ridiculous that we have to go to these lengths to do something that should be handled by the application
This comment was minimized by the moderator on the site
Hi! How can this work if having multiple emails? Is this only for multiple attachments in same email? Thanks!
This comment was minimized by the moderator on the site
Hey there! Do you know how we can improve the below code to rename the file when saved?

Public Sub UnzipFileInOutlook(itm As Outlook.MailItem)
Dim objAtt As Outlook.Attachment
Dim saveFolder As String
saveFolder = "C:\Users\acheng\Desktop"
For Each objAtt In itm.Attachments
objAtt.SaveAsFile saveFolder
Set objAtt = Nothing
Next
End Sub
This comment was minimized by the moderator on the site
Hello, Lipe, may be this code can help you.

Private Sub CopyToDefaultCalendarFld(ByVal Item As Object)
Dim xCopiedAppointment As Outlook.AppointmentItem
Dim xMovedAppointment As Outlook.AppointmentItem
Dim xMeeting As MeetingItem
Dim xApoint As AppointmentItem
On Error Resume Next
If Item.Class = olAppointment Then
Set xApoint = Item
Set xCopiedAppointment = xApoint.Copy
Set xMovedAppointment = xCopiedAppointment.Move(GMovedCalendarFolder)
If xApoint.Subject <> xMovedAppointment.Subject Then
If InStr(1, xMovedAppointment.Subject, "Copy: ") > 0 Then
xMovedAppointment.Subject = VBA.Replace(xMovedAppointment.Subject, "Copy: ", "", 1, 1)
xMovedAppointment.Save
End If
End If
ElseIf Item.Class = olMeetingRequest Then
Set xMeeting = Item
Set xCopiedAppointment = xMeeting.GetAssociatedAppointment(True).Copy
Set xMovedAppointment = xCopiedAppointment.Move(GMovedCalendarFolder)
If xMeeting.Subject <> xMovedAppointment.Subject Then
If InStr(1, xMovedAppointment.Subject, "Copy: ") > 0 Then
xMovedAppointment.Subject = VBA.Replace(xMovedAppointment.Subject, "Copy: ", "", 1, 1)
xMovedAppointment.Save
End If
End If
xCopiedAppointment.Delete
End If
Set xCopiedAppointment = Nothing
End Sub
There are no comments posted here yet
Please leave your comments in English
Posting as Guest
×
Rate this post:
0   Characters
Suggested Locations