Formato e cálculo do AppleScript Date

1

Eu trabalho com três formatos de data,

1 04/18/2015 (PS minha data do sistema não é a mesma, mas DD / MM / AA)

2 2 de junho de 2012 mas convertido para o 1º formato por código abaixo

3 Sábado, 24 de março de 2018 (data atual)

Acabei de criar o script abaixo para converter as duas datas no mesmo formato:

set creationDate to "March 23rd, 2018"
set CreationDay to ""
set Creationmonth to ""
set Creationyear to ""


if creationDate contains "1st" then
    set CreationDay to "1"
end if
if creationDate contains "2nd" then
    set CreationDay to "2"
end if
if creationDate contains "3rd" then
    set CreationDay to "3"
end if
if creationDate contains "4th" then
    set CreationDay to "4"
end if
if creationDate contains "5th" then
    set CreationDay to "5"
end if
if creationDate contains "6th" then
    set CreationDay to "6"
end if
if creationDate contains "7th" then
    set CreationDay to "7"
end if
if creationDate contains "8th" then
    set CreationDay to "8"
end if
if creationDate contains "9th" then
    set CreationDay to "9"
end if
if creationDate contains "10th" then
    set CreationDay to "10"
end if
if creationDate contains "11th" then
    set CreationDay to "11"
end if
if creationDate contains "12th" then
    set CreationDay to "12"
end if
if creationDate contains "13th" then
    set CreationDay to "13"
end if
if creationDate contains "14th" then
    set CreationDay to "14"
end if
if creationDate contains "15th" then
    set CreationDay to "15"
end if
if creationDate contains "16th" then
    set CreationDay to "16"
end if
if creationDate contains "17th" then
    set CreationDay to "17"
end if
if creationDate contains "18th" then
    set CreationDay to "18"
end if
if creationDate contains "19th" then
    set CreationDay to "19"
end if
if creationDate contains "20th" then
    set CreationDay to "20"
end if
if creationDate contains "21st" then
    set CreationDay to "21"
end if
if creationDate contains "22nd" then
    set CreationDay to "22"
end if
if creationDate contains "23rd" then
    set CreationDay to "23"
end if
if creationDate contains "24th" then
    set CreationDay to "24"
end if
if creationDate contains "25th" then
    set CreationDay to "25"
end if
if creationDate contains "26th" then
    set CreationDay to "26"
end if
if creationDate contains "27th" then
    set CreationDay to "27"
end if
if creationDate contains "28th" then
    set CreationDay to "28"
end if
if creationDate contains "29th" then
    set CreationDay to "29"
end if
if creationDate contains "30th" then
    set CreationDay to "30"
end if
if creationDate contains "31st" then
    set CreationDay to "31"
end if

if creationDate contains "2018" then
    set Creationyear to "2018"
end if
if creationDate contains "2017" then
    set Creationyear to "2017"
end if
if creationDate contains "2016" then
    set Creationyear to "2016"
end if
if creationDate contains "2015" then
    set Creationyear to "2015"
end if
if creationDate contains "2014" then
    set Creationyear to "2014"
end if
if creationDate contains "2013" then
    set Creationyear to "2013"
end if
if creationDate contains "2012" then
    set Creationyear to "2012"
end if
if creationDate contains "2011" then
    set Creationyear to "2011"
end if
if creationDate contains "2010" then
    set Creationyear to "2010"
end if
if creationDate contains "2009" then
    set Creationyear to "2009"
end if
if creationDate contains "2008" then
    set Creationyear to "2008"
end if
if creationDate contains "2007" then
    set Creationyear to "2007"
end if
if creationDate contains "2006" then
    set Creationyear to "2006"
end if
if creationDate contains "2005" then
    set Creationyear to "2005"
end if
if creationDate contains "2004" then
    set Creationyear to "2004"
end if
if creationDate contains "2003" then
    set Creationyear to "2003"
end if


if creationDate contains "January" then
    set Creationmonth to "01"
end if
if creationDate contains "February" then
    set Creationmonth to "02"
end if
if creationDate contains "March" then
    set Creationmonth to "03"
end if
if creationDate contains "April" then
    set Creationmonth to "04"
end if
if creationDate contains "May" then
    set Creationmonth to "05"
end if
if creationDate contains "June" then
    set Creationmonth to "06"
end if
if creationDate contains "July" then
    set Creationmonth to "07"
end if
if creationDate contains "Agust" then
    set Creationmonth to "08"
end if
if creationDate contains "September" then
    set Creationmonth to "09"
end if
if creationDate contains "October" then
    set Creationmonth to "10"
end if
if creationDate contains "November" then
    set Creationmonth to "11"
end if
if creationDate contains "December" then
    set Creationmonth to "12"
end if


set CreationfinalDate to CreationDay & "/" & Creationmonth & "/" & Creationyear
return CreationfinalDate

Pergunta 1: Como posso converter o número de data 3 (que é a data atual) para o mesmo formato

(Eu sei como retornar como uma corda, mas não o contrário)

set myDate to date string of (current date)

Pergunta 2: posso criar um script para informar se a diferença entre a data 2 e a data 3 está dentro de 60 dias ou fora de 60 dias?

Kevin
fonte

Respostas:

4

Questão 1: Ao invés de passar pelo problema de obter o current date apenas para convertê-lo em outro formato, você pode obtê-lo no formato correto imediatamente com um comando bash:

    do shell script "date +'%m/%d/%Y'"
        --> 03/24/2018

Questão 2: Primeiro, reformate a data naquilo que seu sistema pode reconhecer. No seu caso (e meu), é dd/mm/yyyy:

    set [M, ordinal, Y] to the words of "June 2nd, 2012"

    set the text item delimiters to {"st", "nd", "rd", "th"}
    set cardinal to (first text item of ordinal) --> "2"
    set cardinal to text -1 thru -2 of ("0" & cardinal) --> "02"

    set the text item delimiters to space
    set date_string to {M, cardinal, Y} as text

    -- date -j -f '%B %d %Y' 'June 02 2012' +'%d/%m/%Y'
    set command to {¬
        "date -j -f '%B %d %Y'", ¬
        quoted form of the date_string, ¬
        "+'%d/%m/%Y'"}

    do shell script (command as text) --> "02/06/2012"

Em seguida, subtraia uma data da data atual e divida por days para obter o número de dias entre as duas datas:

    ((current date) - (date result)) / days
        --> 2121.627

PS. Você pode usar o mesmo comando shell para converter a data em seu primeiro formato, mm/dd/yyyy, simplesmente trocando %d e %m no final de command corda.


TERMO ADITIVO:

Eu pensei em mostrar também como converter a terceira string de data em seu formato desejado usando o AppleScript puro. Isso pode ser feito bastante elegantemente, na verdade:

    set today to "Saturday 24 March 2018"

    set [_day, _month, _year] to [day, month, year] of date today
        --> {24, March, 2018}

    set _month to _month * 1 --> 3
    set _month to text -1 thru -2 of ("0" & _month) --> "03"

    set the text item delimiters to "/"
    return {_month, _day, _year} as string
        --> "03/24/2018"

Nota para outros usuários: O código neste adendo pode ou não funcionar para você, dependendo das configurações do sistema. O AppleScript é notoriamente exigente sobre o que ele irá e não reconhecerá como uma string de data. OP e eu parecemos ter semelhante ou idêntico Idioma & amp; Região data settings, que permite a variável today para ser interpretado corretamente como uma data pelo AppleScript, enquanto o mesmo código em execução em um sistema diferente causaria um erro.

Para adaptar o código aqui para uso em seu próprio sistema, primeiro execute o comando get date string of (current date) para obter uma visualização do formato de data usado pelo sistema, em seguida, altere a declaração de variável para today para combinar. Como alternativa, defina a variável today para the date string of (current date).

CJK
fonte
isso é perfeito muito obrigado, exatamente o que precisava
Kevin
0

Coerce sua data em um AppleScript date objeto, então você pode executar cálculos como set myNewDate to myDate + (2 * days). Para mais cálculos de data, consulte Cálculos de data / hora usando o AppleScript e Guia da Linguagem AppleScript - Data .

Abaixo está uma abordagem alternativa para analisar o terceiro formato de data, mais detalhado. Essa abordagem usa sub-rotinas para dividir e aparar a entrada. Não está completo, mas espero que seja útil:

set myDate to "March 1st, 2018"
set myComponents to my split(myDate, " ")

set myDay to second item of myComponents
set myDay to trim(",rdsth", myDay) as integer

set myMonth to first item of myComponents
set myYear to last item of myComponents as integer

-- ...myDay, myMonth, and myYear are usable

-- http://erikslab.com/2007/08/31/applescript-how-to-split-a-string/
on split(theString, theDelimiter)
    -- save delimiters to restore old settings
    set oldDelimiters to AppleScript's text item delimiters
    -- set delimiters to delimiter to be used
    set AppleScript's text item delimiters to theDelimiter
    -- create the array
    set theArray to every text item of theString
    -- restore the old setting
    set AppleScript's text item delimiters to oldDelimiters
    -- return the result
    return theArray
end split

-- https://macscripter.net/viewtopic.php?id=18519
on trim(theseCharacters, someText)
    -- Lazy default (AppleScript doesn't support default values)
    if theseCharacters is true then set theseCharacters to ¬
        {" ", tab, ASCII character 10, return, ASCII character 0}

    repeat until first character of someText is not in theseCharacters
        set someText to text 2 thru -1 of someText
    end repeat

    repeat until last character of someText is not in theseCharacters
        set someText to text 1 thru -2 of someText
    end repeat

    return someText
end trim
Graham Miln
fonte
Esse trabalho também, mas isso faz mais sentido, suponho, no entanto definir myFinalDae para myMonth & amp; "/" & amp; myDay & amp; "/" & amp; myYear return "March / 1/2018" Eu tenho uma visão melhor em um segundo
Kevin