Bir Word belgesindeki tüm alanları nasıl güncellerim?


97

Word 2013 belgesindeki tüm alanları güncelleştirmenin bir yolunu istiyorum . (Eğer diğer sürümlerde çalışıyorsa, hepsinden daha iyisi; Word 2007 ile asıl sorunum vardı ve o zamandan beri hiçbir şey değişmedi.) Buna çapraz referanslar, sayfa numaraları, içindekiler tablosu, dizinler, başlıklar vb. Tuşuna basarak güncellenebilirse F9, güncellenmesini istiyorum.

(Teorik olarak güncelleme alanları başka alanların güncellenmesine neden olabilir, örneğin daha uzun bir içindekiler ana metindeki bazı sayfa numaralarını değiştirir. Yaygın durumlara dikkat etmek benim için yeterlidir. Aslında, çalıştırmam gerekirse makro stabilize etmeden iki veya üç kez önce. Sadece her şeyi bulan tek bir makroya sahip olmak istiyorum.)

Şimdiye kadar yaptığım girişimi rakamların içindeki metin kutularındaki alanları güncellemiyor. Onları nasıl güncellerim ve başka neleri kaçırdım?


EDIT : Sahip olduğum cevap ile verilen cevapları birleştirmek, her şeyi ( bilinen bir kusurla ) güncelleyen bir makro verir .

'' Update all the fields, indexes, etc. in the specified document.
Sub UpdateAllFieldsIn(doc As Document)
    '' Update tables. We do this first so that they contain all necessary
    '' entries and so extend to their final number of pages.
    Dim toc As TableOfContents
    For Each toc In doc.TablesOfContents
        toc.Update
    Next toc
    Dim tof As TableOfFigures
    For Each tof In doc.TablesOfFigures
        tof.Update
    Next tof
    '' Update fields everywhere. This includes updates of page numbers in
    '' tables (but would not add or remove entries). This also takes care of
    '' all index updates.
    Dim sr As range
    For Each sr In doc.StoryRanges
        sr.Fields.Update
        While Not (sr.NextStoryRange Is Nothing)
            Set sr = sr.NextStoryRange
            '' FIXME: for footnotes, endnotes and comments, I get a pop-up
            '' "Word cannot undo this action. Do you want to continue?"
            sr.Fields.Update
        Wend
    Next sr
End Sub
'' Update all the fields, indexes, etc. in the active document.
'' This is a parameterless subroutine so that it can be used interactively.
Sub UpdateAllFields()
    UpdateAllFieldsIn ActiveDocument
End Sub

1
Dim toa As Word.TableOfAuthorities / For Each toa In ActiveDocument.TablesOfAuthorities / toa.Update / Next
Bütünlüğü

Bunu Word 2013'te denedim ve hala çalıştığını doğrulayan bir kafa buluyorum. @Gilles kodunu verdiğiniz için çok teşekkür ederiz!
Ugo

Önizlemeyi yazdırmak ve belgeye geri dönmek için giden bir makro ne durumda?
Pedro77

@ Pedro77 Bunun nasıl bir yardımı olabilir? En azından Word 2013 ile (artık Word 2007’ye erişimim yok), önizlemenin basılması ya da bu konuda basılması için alanlar güncellenmiyor.
Gilles

Alanlarım güncellendi, en azından referanslar ve çapraz referans alanları.
Pedro77

Yanıtlar:


37

Baskı ayarlarına gidin, güncelleme alanlarını seçin. Sonra yazdırın veya dokümanınızı önizleyin.

Ve voilà, tüm alanlar güncellendi!

Mac 2016'dan MS Word Yazdırma Seçenekleri


2
Şimdi benim için Word 2010'da çalışıyorum (ayar “Dosya → Seçenekler → Ekran” konumunda). Aslında, seçenek olmadan bazı alanlar güncellenir ancak hepsi güncellenmez. Word 2007'de olmadığından eminim ama artık test edeceğim yok.
Gilles

2
Mac için Word 2016’dayım. Ayar Word -> Tercihler -> Yazdır seçeneğindedir. Ancak dullarda, küresel ayarların baskı bölümünde olacaktır. Eminim geçmişte orada bulundum, ancak şu anda test edeceğim bir kurulumum yok.
David Roussel

Sanırım bu artık Word 2016'da çalışmıyor.
TCB13

Bu benim için Windows 7'de Word 2016'da çalıştı.
bouvierr

Word 2016 Windows'ta çalışmıyor. Örneğin altbilgilerdeki alanlar doğru şekilde güncellenmedi.
Hobbes

80

Ben sadece Ctrl+ ' Ayı yapıyorum - her şeyi seçmek için - ve ardından F9 lotu güncellemek için.

Bununla birlikte, bu başlık ve altbilgileri özlüyor, ancak IIRC'yi yazdırdığınızda / önizlediğinizde yazdırıyorlar.


Güncelleme

Aşağıdaki makroyu buldum. Hızlı bir testte, içindekiler tablosu, paragraf içindeki alanlar, üstbilgi ve altbilgi içindeki alanlar ve değişken metin kutusu içindeki alanlar güncellenmiştir.

Umarım ihtiyacınız olan her şeyi kapsar, lütfen güncellemede neyin başarısız olduğunu belirtmeyin.

Kaynak: http://www.gmayor.com/installing_macro.htm

Sub UpdateAll()
    Dim oStory As Range
    For Each oStory In ActiveDocument.StoryRanges
        oStory.Fields.Update
        If oStory.StoryType <> wdMainTextStory Then
            While Not (oStory.NextStoryRange Is Nothing)
                Set oStory = oStory.NextStoryRange
                oStory.Fields.Update
            Wend
        End If
    Next oStory
    Set oStory = Nothing
End Sub

@Giles - Tamam, yeterince adil, her zaman temel ilklerin araştırıldığını kontrol etmek için en iyisi. Şimdi bir avım oldu ve işi yapan bir makro buldum, güncellememi kontrol et, bir şey özlüyorsa haberim olsun.
DMA57361

Şimdi konuşuyoruz! Neden NextStoryRangeve ile yinelemenin document.StoryRangesfarklı şeyler olduğu hakkında hiçbir fikrim yok , ancak kod güncellemeleriyle birleştiğinde kodum zaten bir kazanan oldu (peki, neredeyse , ama bu farklı bir konu).
Gilles,

Bu, üstbilgi / altbilgide bulunan metin kutularındaki alanlar için çalışmaz. Word 2016'da kontrol edildi
slobo

5

Bu sayfa ilginç görünüyor:

Word 2007 kullanıyorsanız, işlem biraz farklıdır: Office düğmesini ve ardından Word Seçenekleri'ni tıklatın. Word, Word Seçenekleri iletişim kutusunu görüntüler. İletişim kutusunun sol tarafındaki Gelişmiş'e tıklayın. (İlgili rakamı görmek için buraya tıklayın.) Genel alanında (görmek için biraz aşağı kaydırın), Açıldığında Otomatik Bağlantıları Güncelle onay kutusunun seçili olduğundan emin olun. Tamam'a tıklayın. Bu ayar, tüm bağlantılarınızın her zaman güncel olduğundan emin olmalıdır. Belge açıldığında alanları güncellemek istiyorsanız, görevi gerçekleştirmek için bir makro kullanmanız gerekir. Özellikle, belge açıldığında veya kapandığında alanları güncellemek isteyip istemediğinize bağlı olarak bir AutoOpen veya AutoClose makrosu kullanmanız gerekir. Aşağıdakiler, kullanabileceğiniz bir AutoOpen makrosu örneğidir.

Sub AutoOpen()
    With Options
        .UpdateFieldsAtPrint = True
        .UpdateLinksAtPrint = True
    End With
    ActiveDocument.Fields.Update
End Sub

Makro, yazdırma sırasında alanları ve bağlantıları güncelleştirmeye zorlamak için seçeneklerin ayarlandığından emin olduktan sonra belgedeki Alanlar koleksiyonunun tüm üyelerini günceller. Bunun yerine, kapanıştaki alanları güncellemek istiyorsanız, bu makroyu kullanabilirsiniz:

Sub AutoClose()
    ActiveDocument.Fields.Update
End Sub

Bu makro çok daha kısadır çünkü belgeden çıkarken yazdırırken güncelleme seçeneklerini ayarlamanıza gerek yoktur.


4

Word 2010:

Şeridi sağ tıklayın, şeridi özelleştirin, "tüm komutlar" arasından "güncelleme" komutunu seçin ve istediğiniz yere ekleyin.

Bu düğme yalnızca seçilen alanları günceller.
Sonra tüm alanları basın güncellemek için Ctrl+ Asonra bu düğmeye.


Basmaktan ne kadar farklı F9? Bu gerçekten rakamlar, tablolar vb. İçinde güncelleniyor mu?
Gilles,

1
Artık Word 2013'üm var, kontrol ettim. Bu, F9'a basmakla aynı şeyi yapıyor gibi görünmektedir. Bu soruyu sormak için temel motivasyonum olan rakamlar içindeki alanları güncellemiyor.
Gilles

3

Tüm üstbilgileri ve altbilgileri düzgün bir şekilde güncellemek istiyorsanız, bu benim için çalıştı:

    Dim oStory As Range
    Dim oSection As Object
    Dim oHeader As Object
    Dim oFooter As Object

    For Each oStory In ActiveDocument.StoryRanges
        oStory.Fields.Update
    Next oStory

        For Each oSection In ActiveDocument.Sections
             For Each oHeader In oSection.Headers
                 oHeader.Range.Fields.Update
             Next oHeader

             For Each oFooter In oSection.Footers
                 oFooter.Range.Fields.Update
             Next oFooter
        Next oSection

Bu kabul edilen cevapta nasıl iyileşir ? Metin kutularındaki alanları rakamlarla günceller mi?
Gilles,

2

C # için:

using System;
using System.Collections.Generic;
using System.IO;
using Microsoft.Office.Interop.Word;

class Program
{
    static void Main(string[] args)
    {
        List<string> path = new List<string>(args);

        string filePathstr = string.Join(" ", path.ToArray());
        //System.Windows.Forms.MessageBox.Show("filepathstr: " + filePathstr);

        string folderPathstr = Path.GetDirectoryName(filePathstr);
        //System.Windows.Forms.MessageBox.Show("folderPathstr: " + folderPathstr);

        try
        {
            Application ap = new Application();
            Document document = ap.Documents.Open(filePathstr);
            document.Fields.Update();

            foreach (Section section in document.Sections)
            {
                document.Fields.Update();  // update each section

                HeadersFooters headers = section.Headers;  //Get all headers
                foreach (HeaderFooter header in headers)
                {
                    Fields fields = header.Range.Fields;
                    foreach (Field field in fields)
                    {
                        field.Update();  // update all fields in headers
                    }
                }

                HeadersFooters footers = section.Footers;  //Get all footers
                foreach (HeaderFooter footer in footers)
                {
                    Fields fields = footer.Range.Fields;
                    foreach (Field field in fields)
                    {
                        field.Update();  //update all fields in footers
                    }
                }
            }    

            document.Save();
            document.Close();

        }
        catch (NullReferenceException)
        {
            System.Windows.Forms.MessageBox.Show("A valid file was not selected.");
        }
    }
}
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.