BookmarkSubscribeRSS Feed
DocMartin
Quartz | Level 8

I'm using Pandas read_sas method to read a SAS data set into Python. The problem is that a SAS data set stores datetime values as seconds since 1/1/1960 (I think that's right). I want to use Pandas' datetime module, but it expects a datetime format, not an integer. Is there any way around this?

 

Here's my code: 

from tkinter.filedialog import askopenfilename

import numpy as np

import pandas as pd

import datetime as dt

 

infileName = askopenfilename() main1 = pd.read_sas(infileName, index='SUBID', format='sas7bdat') main2 = main1.loc[: , ['APS', 'Age', 'Diabetes', 'hosdead', 'icudead', 'mv', 'hospid', 'iculos', 'ICU_TYPE', 'visit', 'dx', 'dx1', 'IADMDTTM', 'IDISDTTM', 'HADMDTTM', 'HDISDTTM']] _ = main2.dropna(thresh=12, inplace=True)

 

The statement below is where I run into problems.

ilos = dt.timedelta(dt.datetime(main2.loc[:, 'IDISDTTM']) - dt.datetime(main2.loc[:,'IADMDTTM']))

11 REPLIES 11
alexal
SAS Employee

@DocMartin,

 

I would use something like that, do not forget that it will be UTC time. If you need a local time, you have to do TZ conversion too.

 

#!/usr/bin/python
import datetime
sas_time = 1201972927
time = datetime.datetime.fromtimestamp(sas_time + 315619200).isoformat()
print(time)
DocMartin
Quartz | Level 8

I'm trying to broadcast the function across all date-time values. When I issue this command (IADMDTTM is ICU admission time):

 

main2['iadmdttm'] = dt.datetime.fromtimestamp(main2['IADMDTTM'] + 315619200).isoformat()

 

I get this error:

 

TypeError: cannot convert the series to <class 'int'>

 

So I'm not sure what to do. 😞

alexal
SAS Employee

@DocMartin,

 

Are you sure that main2['IADMDTTM'] is a timestamp? Run these lines:

 

print(isinstance(main2['IADMDTTM'], int))
print(main2['IADMDTTM'])
DocMartin
Quartz | Level 8
No. main2['IADMDTTM'] is the SAS integer representation of the date-time.
alexal
SAS Employee

@DocMartin,


Show me the output of the program above, please.

DocMartin
Quartz | Level 8
print(isinstance(main2['IADMDTTM'], int))
print(main2['IADMDTTM'])
False
SUBID
b'B1000001790' 1.741629e+09
b'B1000001848' 1.756993e+09
etc...
alexal
SAS Employee

@DocMartin,

 

Here you go. This is an object and the object type isn't an int. Give me a few minutes to check Pandas read_sas method. I've never used it before.

alexal
SAS Employee

@DocMartin,

 

Actually, you do not need to convert anything. Check this program. I've read BUY dataset from SASHELP:

 

import pandas as pd
buy = pd.read_sas("/home/alex/buy.sas7bdat")
/* Just print */
print(buy)
/* If you want to iterate over each row, you can do this */
for index, row in buy.iterrows():
  print(row['DATE'])
  print(row['AMOUNT'])

Results:

python pandas_read_sas.py
         DATE    AMOUNT
0  1996-01-01 -110000.0
1  1997-01-01   -1000.0
2  1998-01-01   -1000.0
3  1999-01-01  -51000.0
4  2000-01-01   -2000.0
5  2001-01-01   -2000.0
6  2002-01-01   -2000.0
7  2003-01-01   -2000.0
8  2004-01-01   -2000.0
9  2005-01-01   -2000.0
10 2006-01-01   48000.0
1996-01-01 00:00:00
-110000.0
1997-01-01 00:00:00
-1000.0
1998-01-01 00:00:00
-1000.0
1999-01-01 00:00:00
-51000.0
2000-01-01 00:00:00
-2000.0
2001-01-01 00:00:00
-2000.0
2002-01-01 00:00:00
-2000.0
2003-01-01 00:00:00
-2000.0
2004-01-01 00:00:00
-2000.0
2005-01-01 00:00:00
-2000.0
2006-01-01 00:00:00
48000.0
DocMartin
Quartz | Level 8
When I use that code on main2, I still get SAS date-time float values.
DocMartin
Quartz | Level 8
I partially found a solution. main2['iadmdttm'] = pd.to_datetime((main2['IADMDTTM'] + 315619200)) But the date-time values are: 1970-01-01 00:00:02.057248200 1970-01-01 00:00:02.072612280 etc... rather than date-times from around 1/1/2016
alexal
SAS Employee

@DocMartin,

 

I would like to review the output from this:

 

print(main2.dtypes)

sas-innovate-wordmark-2025-midnight.png

Register Today!

Join us for SAS Innovate 2025, our biggest and most exciting global event of the year, in Orlando, FL, from May 6-9. Sign up by March 14 for just $795.


Register now!

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 11 replies
  • 10567 views
  • 0 likes
  • 2 in conversation