תכנות

4.6k נושאים 37.8k פוסטים

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


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

    שלום לכולם
    התבקשתי רבות מחברים פיתרון לבעיה הידועה לבצע מיזוג דואר, אך לשמור קובץ 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 פוסטים

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

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

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

  • 31 נושאים
    133 פוסטים

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

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

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

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

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

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

  • ערך רנדומלי בשדה mysql.

    4
    1 הצבעות
    4 פוסטים
    72 צפיות

    @chagold אמר בערך רנדומלי בשדה mysql.:

    מה לא הבנתי טוב?

    תשתמש בקידומת NEW עבור השדה החדש שנוצר, כך:

    CREATE TRIGGER trigger_code BEFORE INSERT ON user FOR EACH ROW SET NEW.token=MD5( RAND ());
  • יצירת והורדת קובץ TXT ב PHP

    הועבר
    8
    0 הצבעות
    8 פוסטים
    380 צפיות

    @WWW יפה!
    למקרים של טקסטים גדולים אפשר להשתמש בblob:

    function download_txt(textToSave, fileName) { var blob = new Blob([textToSave], { type: 'text/plain' }); var hiddenElement = document.createElement('a'); hiddenElement.href = window.URL.createObjectURL(blob); hiddenElement.target = '_blank'; hiddenElement.download = fileName; hiddenElement.click(); } var text = document.getElementById('txt')?.value ?? 'טקסט לדוגמה' download_txt(text ,'myFile.txt');
  • 0 הצבעות
    8 פוסטים
    201 צפיות

    @ivrtikshoret
    להחליף את הtextarea ב-contenteditable (תוסיף גם name=textarea.name, ופרוקסי לפונקציית ()VAL. כדי שזה יעבוד בצורה שקופה)

  • התקנת גופנים על ידי חילוץ עצמי.

    הועבר
    7
    1 הצבעות
    7 פוסטים
    102 צפיות

    @הללוהו כן, ככה:

    copy /y MyFontName.ttf "%SYSTEMROOT%\Fonts" reg add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Fonts" /v "My Font (TrueType)" /t REG_SZ /d MyFontName.ttf /f copy /y AnotherFontName.ttf "%SYSTEMROOT%\Fonts" reg add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Fonts" /v "Another Font (TrueType)" /t REG_SZ /d AnotherFontName.ttf /f

    וכו'.

  • שרת אישי על המחשב שלי

    13
    0 הצבעות
    13 פוסטים
    216 צפיות

    @yossiz זה באמת כלי נפלא. וכבר השתמשתי. ועם התוספת של היוזר והסיסמה אז בכלל.
    נראה שהם שמו בעדיפות גדולה את פשטות השימוש - והצליחו בגדול.

  • 1 הצבעות
    9 פוסטים
    196 צפיות

    @yossiz אמר בבירור | שמות קיצורי הדרך לנתיבים בתיקיות:

    אתה רוצה ספר או סט ספרים? 🙂

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

    @yossiz אמר בבירור | שמות קיצורי הדרך לנתיבים בתיקיות:

    זה לא משהו שאפשר להגיד את הכל על רגל אחת

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

  • 0 הצבעות
    5 פוסטים
    78 צפיות

    @אבי-203 שים לב שמכיוון שTrunc מעגל לכיוון האפס, ההתנהגות עבור מספרים שליליים תהיה זהה לזו של Ceil, כלומר העיגול יתבצע כלפי מעלה.

    לסיכום:

    מתודה תוצאה Floor עיגול כלפי מטה לכיוון האינסופי השלילי (Negative infinity או ∞-) Ceil עיגול כלפי מעלה לכיוון האינסופי החיובי (Positive infinity או ∞) Trunc עיגול כלפי מטה\מעלה לכיוון האפס
  • 22 הצבעות
    24 פוסטים
    958 צפיות

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

    או שמא האינטואציה שלי לא עבדה כרגע ולכן לא הבנתי.
    כי לא הפעלתי כ"כ את ההגיון (באופן לוגי וקוגניטיבי) לפני שכתבתי את הפוסט 👶

  • cmd | סגירה בסיום ההפעלה

    הועבר
    14
    0 הצבעות
    14 פוסטים
    317 צפיות

    @odeddvir אמר בcmd | סגירה בסיום ההפעלה:

    לפי התיעוד של מייקרוסופט

    שנמצא אגב גם במחשב (help start)

  • Caddy Web-Server

    6
    3 הצבעות
    6 פוסטים
    110 צפיות

    @chv
    הסיבה שהוא איטי זה ככל הנראה בגלל שהוא כתוב בGO שבאופן כללי נחשבת שפה יותר איטית בגלל הgc, העניין הוא שאם משמשים בנוד מאחורה זה כנראה לא משנה כל כך.

  • איך בוחרים את הטכנולוגיה המתאימה

    16
    6 הצבעות
    16 פוסטים
    193 צפיות

    @davidnead אמר באיך בוחרים את הטכנולוגיה המתאימה:

    אגב, דוגמה (מעשית!) נוספת שעומדת לפני.

    מערכת CRM, או ניהול פרוייקטים או ניהול סטודנטים או משהו דומה.

    כלומר לקוח שרוצה מערכת לניהול רבנים ותלמידים ושיעורים ומבחנים וכדומה עם התממשקות עם מערכות אשראי ואקסלים וכדו'.

    אין לי בעיה לבנות מאפס בNODE+VUE. מצד שני לפחות חלק מהפונקציונליות של המערכת הזו היא קלאסית ויש לה כנראה כלים מקובלים. לדידי לפתח אפליקציה ולחפש לשלב בה חלקית כלים קיימים זה לשבור את הראש. מאידך למה לבזבז את זמנו של הלקוח בלבנות מסד נתונים וAPI מאפס?

    מה דעתכם?

    זה גם תלוי מה הלקוח רוצה
    לפעמים הלקוח רוצה דווקא מערכת (ולפעמים הוא מתעקש דווקא על וובית) שנתפרה ממש עבורו (הרבה פעמים זה הדבר היותר נכון - ככה לפחות לדעתי בCRM שקצת יותר ספציפי מהרגיל.)
    [אגב גם לשלוח למתחרים לפעמים זה טוב, כשאתה מרגיש או מבין שיש כזו מערכת מוכנה וחבל סתם לבזבז את זמנו של הלקוח... אא"כ הוא מתעקש כמו שכתבתי]

    אגב, ככל שתמשיך הלאה, יהיו לך קלאסים מוכנים ותבנית ראשונה מוכנה, כך שלא ממש תתחיל מההתחלה בכל פרוייקט. אלא ממקום כלשהו באמצע.
    (כמו שכתב @OdedDvir לגבי האקסס...)

  • קול מחשב באידיש

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

    @ש-ב אמר בקול מחשב באידיש:

    והאם גם במיקרוסופט זה עולה כסף,

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

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

    נסה את Awesome Algorithms (10,000 כוכבים בGithub) ואולי גם את DataStructures-Algorithms, תתבונן היטב ברשימה היא עשויה להכיל את מה שאתה מחפש.
    אגב הסבר נחמד על Big O Notation.

  • פריסת אפליקציה node על אובנטו

    3
    1 הצבעות
    3 פוסטים
    127 צפיות

    @יוסף-בן-שמעון אמר בפריסת אפליקציה node על אובנטו:

    CADDY

    נהדר לא הכרתי את caddy

    @katz אמר בפריסת אפליקציה node על אובנטו:

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

    בקשר ל Nginx יש לך את האתר הבא שמאפשר לך לחולל קונפיגורציה לשירות בכמה קליקים

    https://www.digitalocean.com/community/tools/nginx

  • ENCODING ללא ירידת שורה

    הועבר
    19
    0 הצבעות
    19 פוסטים
    571 צפיות

    אני חושב שיש צורך שאתנצל בפני חברי הפורום היקרים כ"א בשמו הטוב יבורך ובפרט ל@yossiz ול@dovid שגזלו מזמנם היקר לענות לי על השאלות ברצון טוב לעזור..
    בו בזמן שכמו ש@yossiz אמר

    @yossiz אמר בENCODING ללא ירידת שורה:

    בד"כ קשיי הסברה מגיעים מעמעום בהבנה.

    וזה אכן היה המקרה שלי.

    אני בכל זאת אנסה להסביר מה קרה לי פה
    אני רציתי לשלוח בAPI טקסט מסיום שהיה צריך לעבור encodeURI לפני השליחה, אז השתמשתי בencodeURI בשרת (app scripts של גוגל) אבל מה, בפלט של השרת כשהגיע לירידת שורה הוא תירגם את זה ל '%0D%0A' ומצד שני השרת API שקיבל את הJSON לא רצה לקבל את זה וטען שזה לא תקין
    אז אני, במקום לחשוב איך לתקן את זה ולשאול שאלה ספציפית😧, רציתי לעקוף את הבעיה ע"י לא לתת לו לרדת שורה, וחשבתי שכך הבעיה תסתדר, ואת זה שאלתי פה בפורום איך לעשות שלא יהיה ירידת שורה.
    אבל מה? בסוף הבנתי שיש פעמים שאני חייב לשלוח כמה שורות, ולא יעזור לי לעשות פתרונות כאלו, אז ערבבתי את הנושא והתחלתי לשאול איך כן לשלוח את הAPI תקין, ולא הבנתי ולא הובנתי

    בסוף עשיתי replace מ '%0D%0A' ל '%5C%5Cn' ואז הכל הסתדר, אבל שוב, סליחה מכל אלו שניסו לעזור ככל יכולתם ולא אפשרתי להם
    (נ.ב. מקווה שהפוסט הזה כן מובן)

  • override תעלומה

    הועבר
    8
    2 הצבעות
    8 פוסטים
    347 צפיות

    @yyy ביחס ל-CAST.

  • הגדרת מילה שמורה ב PHP

    הועבר
    16
    0 הצבעות
    16 פוסטים
    332 צפיות

    @ass כעת אני מבין שבכלל לא הבנתי אותך מעיקרא. חשבתי שאתה מתלבט איך לשלוח למסד הנתונים את המידע, ולא איך לפענח אותו מקובץ הטקסט. יש"כ ל @שמואל4 שירד בסבלנותו לסוף דעתך.

  • המרת אתר מותאם נייד לאפליקצייה

    7
    0 הצבעות
    7 פוסטים
    90 צפיות

    @אבי-203
    לא
    ההורדה מהאתר שלהם עצמאית
    וגם אח"כ הוא מייר APK שאתה יכול לשלוח למישהו כדי שיבדוק, או לשים באמולטור

  • מחפש מעצב HTML+CSS שעובד עם VUEJS

    הועבר
    2
    0 הצבעות
    2 פוסטים
    100 צפיות
    אין תגובות
  • ריבוי תהליכים ב- NodedJS

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

    @yossiz
    אני מעלה את הנושא כדי לשמוע מניסיונכם במקרים דומים.

    והתשובה שלך אכן עזרה.

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

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