<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Keep the faith in SAS Users Group in Israel</title>
    <link>https://communities.sas.com/t5/SAS-Users-Group-in-Israel/Keep-the-faith/m-p/754794#M261</link>
    <description>&lt;P class="lia-align-right" style="direction: rtl;"&gt;לפני מספר שנים הייתי צריך לכתוב מאקרו שיבצע מספר חישובים סטטיסטים פשוטים: ממוצע, מקסימום, מינימום, סטיית תקן וכו' על כל המשתנים הנומרים בטבלה אשר המאקרו יקבל כפרמטר.&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;לכאורה משהו די פשוט. בעזרת טבלאות ה – dictionary שדיברנו עליהן בעבר ניתן לזהות את המשתנים הנומרים ולאסוף את כולם למקום המתאים ב – proc means. אכן פשוט פרט לנקודה בעייתית אחת – גם משתני תאריך ב – SAS הם משתנים נומרים אבל, כמובן, שאין לכלול אותם בחישובים הסטטיסטים.&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;בעיה, אבל אנחנו דבקים במשימה ואחרי מעט מחשבה הגעתי למסקנה שאני יכול לזהות את משתני התאריך עפ"י הפורמט שמופעל עליהם – אם על משתנה נומרי יש פורמט של תאריך אז בהגדרה מדובר במשתנה שמכיל תאריך – פשוט מאוד.&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;באופן טבעי השאלה הבאה היא מהם פורמטים של תאריך? חיפשתי וחיפשתי שאלתי ושאלתי אבל כל המקורות שלי אמרו שאין רשימה מובנית של פורמטי תאריך ב – SAS צריך פשוט לבנות אחת כזאת ידנית. נשמע לי קצת מוזר ובעייתי, ל – SAS יש מאות פורמטים איך אני יודע שלא פספסתי כמה, אבל הזמן דחק והאויב של הטוב זה המצוין אז יצרתי לי רשימה של פורמטי התאריך הנפוצים ביותר והמשכתי הלאה.&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;השנים עברו ופתאום בעודי עובר להנאתי על התיעוד של הפונקציות ב – SAS (מה, רק אני עושה את זה?) מצאתי את הפתרון – הפונקציה &lt;A href="https://documentation.sas.com/doc/en/pgmsascdc/9.4_3.3/lefunctionsref/n08tazkeygnw9on138axalvpy9p4.htm" target="_self"&gt;FMTINFO&lt;/A&gt; שעבור כל פורמט שהיא מקבלת כפרמטר היא מחזירה לנו מגוון מידע כולל הקטגוריה אליה הוא שייך – מושלם.&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;ככה זה עובד:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data COLUMNS_FORMATS(keep=var_nm format_:);
	set SASHELP.PRDSAL3(obs=1);
	array nums {*} _numeric_; * All the numeric variables;
	length 
		Var_NM		$32
		Format_NM	$8
		Format_Category	$10
		Format_Type		$10
		Format_Desc		$50
		Format_MinD		
		Format_MaxD
		Format_DefD	
		Format_MinW
		Format_MaxW
		Format_DefW		8;
	do i=1 to dim(nums);
		Var_NM=vname(nums[i]);
		Format_NM=vformatn(nums[i]); * We need just the format name without the the width, the dot and the decimal;
		Format_Category=fmtinfo(format_nm, 'cat'); * The jackpot!;
		Format_Type=fmtinfo(format_nm, 'type');
		Format_Desc=fmtinfo(format_nm, 'desc');
		Format_MinD=input(fmtinfo(format_nm, 'mind'), 3.); * fmtinfo always returns strings. We convert these values into numbers;
		Format_MaxD=input(fmtinfo(format_nm, 'maxd'), 3.);
		Format_DefD=input(fmtinfo(format_nm, 'defd'), 3.);
		Format_MinW=input(fmtinfo(format_nm, 'minw'), 3.);
		Format_MaxW=input(fmtinfo(format_nm, 'maxw'), 3.);
		Format_DefW=input(fmtinfo(format_nm, 'defw'), 3.);
		output;
	end;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;חגי&lt;/P&gt;</description>
    <pubDate>Sat, 17 Jul 2021 17:40:52 GMT</pubDate>
    <dc:creator>Hagay</dc:creator>
    <dc:date>2021-07-17T17:40:52Z</dc:date>
    <item>
      <title>Keep the faith</title>
      <link>https://communities.sas.com/t5/SAS-Users-Group-in-Israel/Keep-the-faith/m-p/754794#M261</link>
      <description>&lt;P class="lia-align-right" style="direction: rtl;"&gt;לפני מספר שנים הייתי צריך לכתוב מאקרו שיבצע מספר חישובים סטטיסטים פשוטים: ממוצע, מקסימום, מינימום, סטיית תקן וכו' על כל המשתנים הנומרים בטבלה אשר המאקרו יקבל כפרמטר.&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;לכאורה משהו די פשוט. בעזרת טבלאות ה – dictionary שדיברנו עליהן בעבר ניתן לזהות את המשתנים הנומרים ולאסוף את כולם למקום המתאים ב – proc means. אכן פשוט פרט לנקודה בעייתית אחת – גם משתני תאריך ב – SAS הם משתנים נומרים אבל, כמובן, שאין לכלול אותם בחישובים הסטטיסטים.&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;בעיה, אבל אנחנו דבקים במשימה ואחרי מעט מחשבה הגעתי למסקנה שאני יכול לזהות את משתני התאריך עפ"י הפורמט שמופעל עליהם – אם על משתנה נומרי יש פורמט של תאריך אז בהגדרה מדובר במשתנה שמכיל תאריך – פשוט מאוד.&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;באופן טבעי השאלה הבאה היא מהם פורמטים של תאריך? חיפשתי וחיפשתי שאלתי ושאלתי אבל כל המקורות שלי אמרו שאין רשימה מובנית של פורמטי תאריך ב – SAS צריך פשוט לבנות אחת כזאת ידנית. נשמע לי קצת מוזר ובעייתי, ל – SAS יש מאות פורמטים איך אני יודע שלא פספסתי כמה, אבל הזמן דחק והאויב של הטוב זה המצוין אז יצרתי לי רשימה של פורמטי התאריך הנפוצים ביותר והמשכתי הלאה.&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;השנים עברו ופתאום בעודי עובר להנאתי על התיעוד של הפונקציות ב – SAS (מה, רק אני עושה את זה?) מצאתי את הפתרון – הפונקציה &lt;A href="https://documentation.sas.com/doc/en/pgmsascdc/9.4_3.3/lefunctionsref/n08tazkeygnw9on138axalvpy9p4.htm" target="_self"&gt;FMTINFO&lt;/A&gt; שעבור כל פורמט שהיא מקבלת כפרמטר היא מחזירה לנו מגוון מידע כולל הקטגוריה אליה הוא שייך – מושלם.&lt;/P&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;ככה זה עובד:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data COLUMNS_FORMATS(keep=var_nm format_:);
	set SASHELP.PRDSAL3(obs=1);
	array nums {*} _numeric_; * All the numeric variables;
	length 
		Var_NM		$32
		Format_NM	$8
		Format_Category	$10
		Format_Type		$10
		Format_Desc		$50
		Format_MinD		
		Format_MaxD
		Format_DefD	
		Format_MinW
		Format_MaxW
		Format_DefW		8;
	do i=1 to dim(nums);
		Var_NM=vname(nums[i]);
		Format_NM=vformatn(nums[i]); * We need just the format name without the the width, the dot and the decimal;
		Format_Category=fmtinfo(format_nm, 'cat'); * The jackpot!;
		Format_Type=fmtinfo(format_nm, 'type');
		Format_Desc=fmtinfo(format_nm, 'desc');
		Format_MinD=input(fmtinfo(format_nm, 'mind'), 3.); * fmtinfo always returns strings. We convert these values into numbers;
		Format_MaxD=input(fmtinfo(format_nm, 'maxd'), 3.);
		Format_DefD=input(fmtinfo(format_nm, 'defd'), 3.);
		Format_MinW=input(fmtinfo(format_nm, 'minw'), 3.);
		Format_MaxW=input(fmtinfo(format_nm, 'maxw'), 3.);
		Format_DefW=input(fmtinfo(format_nm, 'defw'), 3.);
		output;
	end;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P class="lia-align-right" style="direction: rtl;"&gt;חגי&lt;/P&gt;</description>
      <pubDate>Sat, 17 Jul 2021 17:40:52 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Users-Group-in-Israel/Keep-the-faith/m-p/754794#M261</guid>
      <dc:creator>Hagay</dc:creator>
      <dc:date>2021-07-17T17:40:52Z</dc:date>
    </item>
  </channel>
</rss>

