Ruby strftime: Başında sıfır olmadan ay?


89

Ruby'nin strftimebaşında sıfır olmadan ay için bir formatı var mı ?

%eGünü baştaki sıfır olmadan aldığımı , ancak ayla hiç şansım olmadığını buldum .

Sonuçta şu şekilde biçimlendirilmiş bir tarih istemek: 9/1/2010


2
Bu 9 Ocak mı yoksa 1 Ekim mi?
TELENT

@telent, ancak müşteri onu yorumluyor :)
Factor Mystic

11
1 Ekim olmadığına eminim .....
Brad

Yanıtlar:


139

Bazı strftimedo sürümleri baştaki sıfırları biçimlendirmek için eksi ile ön eklemeye izin verir , örneğin:

strftime "%-d/%-m/%y"

Ancak bu, strftimesisteminize bağlı olacaktır . Dolayısıyla tutarlılık için bunun yerine şöyle bir şey yapardım:

dt = Time.local(2010, 'Sep', 1)
printf "%d/%d/%d", dt.day, dt.month, dt.year

Eksi, Ruby 1.8.7 ile gayet iyi çalışıyor gibi görünüyor, teşekkürler!
Rob

2
@Rob: Evet, sisteminizin strftimedesteklediği sürece çalışacaktır (örneğin burada, Mac OSX Snow Leopard'ın üzerinde çalışan 1.8.7'de çalışmaz).
draegtun

Ah evet, ubuntu linux'ta 1.8.7 olduğunu açıklığa kavuşturmalıydım
Rob

Benim için çalıştı. 1.9.2p180 Ubuntu'da.
B Yedi

FreeBSD 9'da 1.9.3 ile benim için çalışıyor
user569825

39

İşte gittiğim biçimlendirme listesi. Bu, 2.1.3 için dokümanlardan alınmıştır. Buna göre şunları isteyeceksiniz %-m:

Date (Year, Month, Day):
  %Y - Year with century (can be negative, 4 digits at least)
          -0001, 0000, 1995, 2009, 14292, etc.
  %C - year / 100 (rounded down such as 20 in 2009)
  %y - year % 100 (00..99)

  %m - Month of the year, zero-padded (01..12)
          %_m  blank-padded ( 1..12)
          %-m  no-padded (1..12)
  %B - The full month name (``January'')
          %^B  uppercased (``JANUARY'')
  %b - The abbreviated month name (``Jan'')
          %^b  uppercased (``JAN'')
  %h - Equivalent to %b

  %d - Day of the month, zero-padded (01..31)
          %-d  no-padded (1..31)
  %e - Day of the month, blank-padded ( 1..31)

  %j - Day of the year (001..366)

Time (Hour, Minute, Second, Subsecond):
  %H - Hour of the day, 24-hour clock, zero-padded (00..23)
  %k - Hour of the day, 24-hour clock, blank-padded ( 0..23)
  %I - Hour of the day, 12-hour clock, zero-padded (01..12)
  %l - Hour of the day, 12-hour clock, blank-padded ( 1..12)
  %P - Meridian indicator, lowercase (``am'' or ``pm'')
  %p - Meridian indicator, uppercase (``AM'' or ``PM'')

  %M - Minute of the hour (00..59)

  %S - Second of the minute (00..60)

  %L - Millisecond of the second (000..999)
       The digits under millisecond are truncated to not produce 1000.
  %N - Fractional seconds digits, default is 9 digits (nanosecond)
          %3N  millisecond (3 digits)
          %6N  microsecond (6 digits)
          %9N  nanosecond (9 digits)
          %12N picosecond (12 digits)
          %15N femtosecond (15 digits)
          %18N attosecond (18 digits)
          %21N zeptosecond (21 digits)
          %24N yoctosecond (24 digits)
       The digits under the specified length are truncated to avoid
       carry up.

Time zone:
  %z - Time zone as hour and minute offset from UTC (e.g. +0900)
          %:z - hour and minute offset from UTC with a colon (e.g. +09:00)
          %::z - hour, minute and second offset from UTC (e.g. +09:00:00)
  %Z - Abbreviated time zone name or similar information.

Weekday:
  %A - The full weekday name (``Sunday'')
          %^A  uppercased (``SUNDAY'')
  %a - The abbreviated name (``Sun'')
          %^a  uppercased (``SUN'')
  %u - Day of the week (Monday is 1, 1..7)
  %w - Day of the week (Sunday is 0, 0..6)

ISO 8601 week-based year and week number:
The first week of YYYY starts with a Monday and includes YYYY-01-04.
The days in the year before the first week are in the last week of
the previous year.
  %G - The week-based year
  %g - The last 2 digits of the week-based year (00..99)
  %V - Week number of the week-based year (01..53)

Week number:
The first week of YYYY that starts with a Sunday or Monday (according to %U
or %W). The days in the year before the first week are in week 0.
  %U - Week number of the year. The week starts with Sunday. (00..53)
  %W - Week number of the year. The week starts with Monday. (00..53)

Seconds since the Epoch:
  %s - Number of seconds since 1970-01-01 00:00:00 UTC.

Literal string:
  %n - Newline character (\n)
  %t - Tab character (\t)
  %% - Literal ``%'' character

Combination:
  %c - date and time (%a %b %e %T %Y)
  %D - Date (%m/%d/%y)
  %F - The ISO 8601 date format (%Y-%m-%d)
  %v - VMS date (%e-%^b-%4Y)
  %x - Same as %D
  %X - Same as %T
  %r - 12-hour time (%I:%M:%S %p)
  %R - 24-hour time (%H:%M)
  %T - 24-hour time (%H:%M:%S)

24/10/14 tarihinde en son 2.1.3 dokümanlarına güncellendi


7
Baştaki sıfır olmadan ayı nasıl elde edeceğimi arıyorum ... gün değil.
Shpigford

2
Neden herkes bu gönderiye AŞAĞI oy veriyor? Bu strftime yardımcıları listesine sahip olmanın yararlı olacağını düşünürdüm!
Rob Cameron

4
İnsanların soruyu cevaplamadığı için oy verdiklerini hayal ediyorum. Liste kendi başına oldukça kullanışlıdır, ancak bu seçeneklerin hiçbiri OP'nin talep ettiği ay için baştaki "0" değerini engellemiyor.
Benry

1
+1 Bu soru orijinal soruyu cevaplamasa da, benzer bir şey için Google'da arama yapan diğer insanlar için yararlıdır, ancak tam olarak OP için değil.
David Oneill

1
% e, istenmeyen olabilecek ve mutlaka OP'nin istediği şey olmayan bir önde gelen boşluk (yani "01.01.2012") sağlar.
brad

8

Dokümanlar, sayı biçimini yapılandırmak için bir dizi farklı seçenek gösterir. % -D biçimine ek olarak, şu bayrakları "-" yerine de kullanabilirsiniz:

Flags:
  -  don't pad a numerical output.
  _  use spaces for padding.
  0  use zeros for padding.
  ^  upcase the result string.
  #  change case.
  :  use colons for %z.

7

Benzer bir sorun yaşadım ve strftime("%m")bir tam sayıya dönüştürerek çözdüm.

Örneğin:

strftime("%m")+0 give the current month as integer 'without leading zero'

Basit, zarif olmasa da.

Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.