《SAS编程与数据挖掘商业案例》学习笔记之十九

本文是《SAS编程与数据挖掘商业案例》学习笔记,主要探讨了SAS中的HASH对象用于高效数据处理,自定义FORMAT提升数据可读性,以及正则表达式的应用,如数据验证和文本提取。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

继续《SAS编程与数据挖掘商业案例》学习笔记,本文侧重数据处理实践,包括:HASH对象、自定义format、以及功能强大的正则表达式

一:HASH对象

Hash对象又称散列表,是根据关键码值而直接进行访问的数据结构,是根据关键码值而直接进行访问的数据结构,

sas提供了两个类来处理哈希表,用于存储数据的hash和用于遍历的hiter,hash类提供了查找、添加、修改、删除等方法,hiter提供了用于定位和遍历的firstnext等方法。

优点:键值的查找是在内存中进行的,有利于提高性能;

              hash表可以在数据步运行时,动态的添加更新或删除观测;

              hash表中可以很快的定位数据,减少查找次数;

常用方法:

definekey:定义键

Definedata:定义值

definedone:定义完成,可以载入数据

add:添加键值,如在hash表中已存在,则忽略;

replace:如果健在hash表中存在,则替换,如果不存在则添加键值

remove:清除键值对

find:查找健值,如果存在则将值写入对应变量

check:查找键值,如果存在则返回rc=0,不修改当前变量的值;

output:将hash表输出到数据集

clear:清空hash表,但并不删除对象

equal:判断两个hash类是否相等

 

find方法的示例:

libname chapt12 'f:\data_model\book_data\chapt12';

data results;

 if _n_=0 then set chapt12.participants;                  

   if _n_ = 1 then do;

    declare hash h(dataset:'chapt12.participants');    

    h.definekey('name');

    h.definedata('gender', 'treatment');

    h.definedone();

  end;

   set chapt12.weight;

  if h.find() = 0 then

    output;

run;

 

hiter对象的引例:

data patients;

  length patient_id $ 16 discharge 8;

  input patient_id discharge:date9.;

datalines;

smith-4123 15mar2004

hagen-2834 23apr2004

smith-2437 15jan2004

flinn-2940 12feb2004

;

data _null_;

  if _n_=0 then set patients;

  declare hash ht(dataset:"patients",ordered:"ascending");

  ht.definekey("patient_id");

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值