[PYTHON] Zeichenbereich / Zeichenfolgenbereich

Ich war neugierig auf das Verhalten des String-Bereichs von Crystal und habe verschiedene Dinge in anderen Sprachen untersucht.

Perl

% perl -v | head -2 | tail -1
This is perl 5, version 14, subversion 2 (v5.14.2) built for x86_64-linux
% perl -e 'print chr ++($foo = ord "Z");'
[
% perl -e 'print ++($foo = "Z");'
AA
% perl -e 'print "A".."Z";'
ABCDEFGHIJKLMNOPQRSTUVWXYZ
% perl -e 'print "A".."z";'
ABCDEFGHIJKLMNOPQRSTUVWXYZ

Das ist intensiv.

% perl -e 'print "a".."Z";'
abcdefghijklmnopqrstuvwxyz
% perl -e 'print "ZZ".."z";'
%

Ruby

$ ruby -v
ruby 2.2.2p95 (2015-04-13 revision 50295) [x86_64-darwin13]
> "Z".ord.succ.chr
=> "["
> "Z".succ
=> "AA"
("A".."z").to_a
=> ["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "[", "\\", "]", "^", "_", "`", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"]
> ("A".."AA").to_a
=> ["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "AA"]
> ("ZZ".."z").to_a
=> ["ZZ"]

Python

$ python -V
Python 3.4.2
In [1]: x = ord("Z"); x += 1; chr(x)
Out[1]: '['

Kann nicht.

Es gibt keine solche Syntax, aber sie kann geschrieben werden.

for x in range(ord("A"), ord("[")):
    print(chr(x), end="")
#=> ABCDEFGHIJKLMNOPQRSTUVWXYZ

Sie können auch "string.ascii_letters" mit "import string" verwenden, jedoch nur im Fall des Alphabets.

for x in string.ascii_letters:
    print(x, end="")
#=> abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ

Kann nicht.

D Sprache

% dmd -v | head -1
DMD64 D Compiler v2.068.0
import std.stdio;

void main()
{
  char x;
  (++(x = 'Z')).writeln;
}
% rdmd x.d
[
import std.stdio;
import std.string;

void main()
{
  "Z".succ.writeln;
}
% rdmd xx.d
AA
import std.stdio;
import std.range;

void main()
{
  iota('A', '[').writeln;
}
% rdmd xxx.d
A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

Kann nicht.

Crystal

% crystal -v
Crystal 0.7.7 [170f859](Sat Sep  5 02:53:51 UTC 2015)
puts 'Z'.succ
% crystal x.cr
[
puts "Z".succ
% crystal x.cr
AA
% cat xx.cr
p ('A'..'z').to_a
% crystal xx.cr
['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '[', '\\', ']', '^', '_', '`', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']

Das ist in Ordnung.

% cat xxx.cr
p ("A".."Z").to_a
% crystal xxx.cr
["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"]

Problemfall.

% cat xxx.cr
p ("A".."z").to_a

"A" -> "Z" -> "AA" -> "ZZ" -> "AAA" -> "AAA .." -> "ZZZ .." wird auf unbestimmte Zeit aufgerufen.

% crystal xxx.cr
^C

Allgemeiner Kommentar

Die Implementierung des String-Bereichs ist ganz anders. Ich habe es hier nicht angegeben, aber Julia und Elixir scheinen den String-Bereich oder das Äquivalent von "String # succ" nicht zu implementieren.

Recommended Posts

Zeichenbereich / Zeichenfolgenbereich
Verschiedene Zeichenkettenoperationen
BLAST ergebnisähnliche Zeichenfolgenanzeige
Datum und Uhrzeit ⇔ Zeichenkette
Python f-Zeichen (formatierte Zeichenfolge)
Reichweite
String-Format
Python UTC ⇔ JST, Zeichenkette (UTC) ⇒ JST-Konvertierungsnotiz
# 5 [python3] Extrahiert Zeichen aus einer Zeichenfolge
Zeichenfolgenformat 2
[Python] So invertieren Sie eine Zeichenfolge
[Python-Anfängermemo] Python-Zeichenfolge, Pfadoperation
Zusammenfassung der Zeichenketten 1
Zeichencode
[Pandas] Erweitern Sie die Zeichenfolgen zu DataFrame
rohe Schnur
Grundlegende Grammatik der Python3-Reihe (Zeichenkette)
Python-String
Python-Grundkurs (4 numerische Typen / Zeichenfolgen)
[PowerShell] Lesen Sie die Zeichenfolge
Ich habe versucht, eine zufällige Zeichenfolge zu generieren
Zusammenfassung einfacher Parser-Implementierungsbeispiele