דילוג לתוכן

תכנות

4.7k נושאים 38.5k פוסטים

קטגוריות משנה


  • 22 נושאים
    137 פוסטים
    katzK

    שלום לכולם
    התבקשתי רבות מחברים פיתרון לבעיה הידועה לבצע מיזוג דואר, אך לשמור קובץ PDF נפרד לכל רשומה, עם שם מותאם אישית.

    אפרט כאן במדריך שלב אחר שלב איך לבצע זאת, תהיו איתי עד הסוף מקווה שתהנו...

    נתחיל...

    שלב א:

    ראשית בקובץ ה- Excel של רשימת הנמענים, הוסיפו לטבלת הנתונים ארבעה עמודות בשמות כדלהלן (חשוב שהשמות יהיו מדויקים ללא רווחים מיותרים - לתשומת ליבכם):

    DocFolderPath

    DocFileName

    PdfFolderPath

    PdfFileName

    שלב ב:
    צרו שתי תיקיות נפרדות, אחד לקבצי הפלט בפורמט docx, ואחד לקבצי הקלט בפורמט pdf, העתיקו את נתיב התיקייה של קבצי ה- docx והדביקו אותם עבור כל רשומה בשדה שיצרתם בשם DocFolderPath, לאחמ"כ חזרו על הפעולה והפעם העתיקו את נתיב התיקייה של קובצי ה- PDF והדביקו בשדה PdfFolderPath.
    בשדה DocFileName כתבו את השם של הקובץ עבור הרשומה - ניתן להשתמש בנוסחאות, כמו"כ בשדה PdfFileName כתבו את שם הקובץ כנ"ל.

    שלב ג:
    פתחו את קובץ ה- word והשלימו את פעולת המיזוג כרגיל, עצבו את המסמך כרצונכם.

    שלב ד:
    פתחו את לשונית מפתחים בקובץ ה- word פתחו את עורך הקוד הוסיפו מודל חדש מצו"ב צילום מסך:
    3eb2538f-9ab1-41eb-a1df-452212916da6-image.png

    הדביקו את הקוד הבא:

    Sub MailMergeToPdfBasic() ' Mark the start of the Subroutine (i.e. Macro) and name it "MailMergeToPdf" ' Macro created by Imnoss Ltd ' Please share freely while retaining attribution ' Last Updated 2021-05-03 Dim masterDoc As Document, singleDoc As Document, lastRecordNum As Long ' Create variables ("Post-it Notes") for later use Set masterDoc = ActiveDocument ' Identify the ActiveDocument (foremost doc when Macro run) as "masterDoc" masterDoc.MailMerge.DataSource.ActiveRecord = wdLastRecord ' jump to the last active record (active = ticked in edit recipients) lastRecordNum = masterDoc.MailMerge.DataSource.ActiveRecord ' retrieve the record number of the last active record so we know when to stop masterDoc.MailMerge.DataSource.ActiveRecord = wdFirstRecord ' jump to the first active record (active = ticked in edit recipients) Do While lastRecordNum > 0 ' create a loop, lastRecordNum is used to end the loop by setting to zero (see below) masterDoc.MailMerge.Destination = wdSendToNewDocument ' Identify that we are creating a word docx (and no e.g. an email) masterDoc.MailMerge.DataSource.FirstRecord = masterDoc.MailMerge.DataSource.ActiveRecord ' Limit the selection to just one document by setting the start ... masterDoc.MailMerge.DataSource.LastRecord = masterDoc.MailMerge.DataSource.ActiveRecord ' ... and end points to the active record masterDoc.MailMerge.Execute False ' run the MailMerge based on the above settings (i.e. for one record) Set singleDoc = ActiveDocument ' Identify the ActiveDocument (foremost doc after running the MailMerge) as "singleDoc" singleDoc.SaveAs2 _ FileName:=masterDoc.MailMerge.DataSource.DataFields("DocFolderPath").Value & Application.PathSeparator & _ masterDoc.MailMerge.DataSource.DataFields("DocFileName").Value & ".docx", _ FileFormat:=wdFormatXMLDocument ' Save "singleDoc" as a word docx with the details provided in the DocFolderPath and DocFileName fields in the MailMerge data singleDoc.ExportAsFixedFormat _ OutputFileName:=masterDoc.MailMerge.DataSource.DataFields("PdfFolderPath").Value & Application.PathSeparator & _ masterDoc.MailMerge.DataSource.DataFields("PdfFileName").Value & ".pdf", _ ExportFormat:=wdExportFormatPDF ' Export "singleDoc" as a PDF with the details provided in the PdfFolderPath and PdfFileName fields in the MailMerge data singleDoc.Close False ' Close "singleDoc", the variable "singleDoc" can now be used for the next record when created If masterDoc.MailMerge.DataSource.ActiveRecord >= lastRecordNum Then ' test if we have just created a document for the last record lastRecordNum = 0 ' if so we set lastRecordNum to zero to indicate that the loop should end Else masterDoc.MailMerge.DataSource.ActiveRecord = wdNextRecord ' otherwise go to the next active record End If Loop ' loop back to the Do start End Sub ' Mark the end of the Subroutine

    שלב ה וסיום:
    סגרו את עורך הקוד.
    לחצו על כפתור פקודות מאקרו שבכרטיסיית מפתחים, בחרו את המאקרו בשם MailMergeToPdfBasic ולחצו הפעל מצו"ב צילום מסך
    3890ce69-c0e9-4f30-89ce-3e97b7de750b-image.png

    כעת שבו בנחת והמתינו עד ליצירת כל הקבצים, להנאתכם תפתחו את תיקיות הפלט שיצרתם וגלו שהיא מלאה קבצים קובץ לכל רשומה בשם המתאים שהגדרתם לה.

    מקור

  • ארכיון האתר הקודם והחביב קוד-613

    1k נושאים
    10k פוסטים
    chagoldC

    @אבי אמר בשוב, צילומי הצ'קים בבנקים:

    התעסקתי לאחרונה עם סורקים של חברת MAGTEK, הם ידידותיים ונוחים להתממשקות, אבל כמדומני שהבנקים בישראל מוכנים לקבל סריקות רק מסורקים של חברת PANINI

    @אבי איך יוצרים אתך קשר?

  • 31 נושאים
    133 פוסטים
    Y.Excel.AccessY

    יש כמה נוסחאות חדשות שממש משנות את כללי המשחק בגוגל שיטס:

    CHOOSECOLS לבחירת עמודות ממערך CHOOSEROWS לבחירת שורות ממערך WRAPROWS להמרת מערך חד ממדי לרב ממדי - פריסה לשורות WRAPCOLS כנ"ל - פריסה לעמודות HSTACK ו VSTACK - הפעולה של {} אך בלי סוגריים - לא משמעותי לכאורה

    והעולה על כולנה, סוף סוף:

    LET - ליצירת משתנים.

    כל אלו מצטרפות לפונקציות שנוספו מוקדם יותר -
    https://blog.sheetgo.com/google-sheets-formulas/10-new-google-sheets-functions/

    וכלול בתוכם - LAMBDA, MAP (חלקי - לא עובד לקנן ב MAP ודומיו מערכים אחרים), פונקציות בעלות שם, וכו' ע"ש בקישור.

  • Stripe - יצירת לקוח לחשבון connect

    3
    0 הצבעות
    3 פוסטים
    52 צפיות
    י

    @dovid הייתי שם... משם הגעתי ללינק שהבאתי, אבל אני לא מבין את המשמעות של זה לגמרי.
    תודה בכל אופן!

  • איך בונים בוט מושלם?

    44
    0 הצבעות
    44 פוסטים
    663 צפיות
    clickoneC

    @nigun אמר באיך בונים בוט מושלם?:

    ואחרי שאני ישקיע הרבה זמן בלהסביר אתה המקרה ואת הצורך ואת מטרת המוצר
    אולי מישהו ימצא את הזמן להקדיש מזמנו לקרוא ולהבין את הכל
    ואז יקדיש דקה מזמנו לחשוב על פתרון בשבילי (אם הוא מידי עמוס)

    יש מישהו עם לב טוב כזה כאן....
    שהכינוי שלו ב613 היה דוד ל.ט (לב טוב)
    כאן זה @dovid ....

  • חסר הרשאות ליוזר ADMIN בMYSQL

    6
    0 הצבעות
    6 פוסטים
    70 צפיות
    ליבלל

    @chagold אמר בחסר הרשאות ליוזר ADMIN בMYSQL:

    לא מבין משהו. הסתדרתי אחרי כמה דקות מאז שפתחתי את האשכול, ומחקתי את ההודעה מיד. (ומופיעה לי בתור מחוקה).
    איך היא עדיין מופיעה לכם?

    את הנושא לא מחקת

  • העלאת קבצים גדולים לימות המשיח

    9
    1 הצבעות
    9 פוסטים
    197 צפיות
    WWWW

    @MusiCode אמר בהעלאת קבצים גדולים לימות המשיח:

    חיסכון של חצי!!

    לא תמיד.

  • 0 הצבעות
    1 פוסטים
    38 צפיות
    אין תגובות
  • NVM לווינדוס, איזה מומלץ?

    2
    0 הצבעות
    2 פוסטים
    44 צפיות
    dovidD

    nvm ממליצים עליהם: https://github.com/coreybutler/nvm-windows

  • 0 הצבעות
    5 פוסטים
    222 צפיות
    יעקב ישראלי

    @רחמים אין לי את הקוד מקור
    אני מנסה את התוכנה של בערל (שמשום מה צריכה אינטרנט)

  • JS ניגון קבצים באתר

    5
    0 הצבעות
    5 פוסטים
    71 צפיות
    ח

    @dovid אמר בJS ניגון קבצים באתר:

    אם אתה רוצה גם על זה אז תביא איזה קטע html מינימלי, כדי שנדבר ישר על אותו רעיון.

    בל"נ כשיהיה לי דוגמה יותר מבוססת אבדוק איפה אני נתקע.
    אני עדיין בשלב ההכנות, רק רוצה להתחיל לסלול את הדרך..

  • 0 הצבעות
    4 פוסטים
    97 צפיות
    dovidD

    אני לא יודע, אני לא רואה פה בעיה.

  • 0 הצבעות
    2 פוסטים
    42 צפיות
    dovidD

    https://support.google.com/webmasters/answer/9370220?hl=iw

  • חסימת אתרים בשבת

    2
    0 הצבעות
    2 פוסטים
    63 צפיות
    א

    http://www.holyclock.com/
    http://www.shomershabes.co.il/site/

  • איך מקובל לעשות היום ajax?

    6
    2 הצבעות
    6 פוסטים
    117 צפיות
    MusiCodeM

    זה תולדה של תפיסה.
    צריך להתחיל קודם עם התפיסה של פרומיס,
    ואז לא מסוגלים לעבוד אחרת.

  • שגיאה בנוסחת אקסל

    הועבר
    7
    0 הצבעות
    7 פוסטים
    252 צפיות
    nachN

    @clickone @WWW
    תודה ענקית! ניסיתי את הפונקציה והיא מתאימה לי בול!! חבל שלא ידעתי עליה עד היום, מעניין שהיא לא מוכרת! אני משתמש המון בפונקציות התניה וזה חוסך זמן כתיבה ומשפר את הקריאות שלה, (כבר חשבתי לכתוב פונקציה חדשה ב VBA, אז תודה שחסכתם לי את העבודה)

  • שימוש ב-MongoDB בנוד

    22
    0 הצבעות
    22 פוסטים
    267 צפיות
    dovidD

    @dovid אמר בשימוש ב-MongoDB בנוד:

    אני כעת חושב שזה יכול לפתור את בעיית הundefined ועוד כמה רעיונות.

    אני לא הייתי ברור, אני מתכוון שהרבה פעמים אני עושה שימוש באובייקט בjs כדי לעשות קיבוץ או פעולות אחרות של set (של key value). אם יש כזה דבר אפשר לעשות פוש לאיבר בלי לדעת אם הוא קיים הוא לא כאילו יש שמה כבר מערך (הפרוקסי ידאג ליצור אותו) וגם לבדוק count וכאלה דברים.
    תוך כדי כתיבה אני חושב שזה לא כזה מציאה כי אחרי הכל זה קוד, ועם פונקציות יכולתי לעשות הכל, אני אחשוב בהמשך למה נראה לי שזה יעזור לי 🙂 .

  • 0 הצבעות
    8 פוסטים
    122 צפיות
    clickoneC

    @שואף
    תפתח על זה אשכול נפרד, אבל על הדרך תכתוב מה יצא לך אם אתה ניגש להשמעה באסטריסק עם כתובת HTTP
    אגב אתה יכול לעשות ללוקלהוסט עם פורט אחר מול התיקייה של הS3 ומשם להשמיע, זה לכאורה יהיה יותר מהר מאשר לצאת החוצה

  • Location php שגיאה

    2
    0 הצבעות
    2 פוסטים
    41 צפיות
    dovidD

    זה קורה כי התחיל כבר להישלח תוכן ללקוח לפני השורה האמורה.
    https://stackoverflow.com/q/8028957/1271037

  • 1 הצבעות
    7 פוסטים
    101 צפיות
    אבי 203א

    יש מישהו שבודק את זה בבוקר. אחד החברים.
    מקווה שיסתדר. אם לא. אשלח בע"ה. תודה רבה בכל אופן.

  • Auto Rename Tag - שינוי קל יותר של תגיות HTML

    8
    10 הצבעות
    8 פוסטים
    257 צפיות
    nachN

    תודה!

  • ממשק מול סאפ

    3
    0 הצבעות
    3 פוסטים
    101 צפיות
    clickoneC

    @משה1
    אני חושב שאפשר לעבוד על הטבלאות עצמם
    בעבר שהם היו על דאטא של אקסס זה היה ככה בוודאות
    אבל גם בMSSQL זה כנראה ככה

    יש כאלו שעושים את זה גם מול תוכנות אחרות כמו APT וכו' (אם אתה מבין את המבנה הפנימי אין סיבה שזה לא יהיה אפשרי)

  • עזרה ב C# | סינון אוביקט מסוג IList

    11
    0 הצבעות
    11 פוסטים
    159 צפיות
    WWWW

    @dovid תודה רבה!
    כולל על הדוגמה 😉

    זה עובד ב"ה!

בא תתחבר לדף היומי!