開発環境
- OS X Mavericks - Apple(OS)
- Xcode 6.0 Beta 6
- Swift (プログラミング言語)
Practical Programming: An Introduction to Computer Science Using Python 3 (Pragmatic Programmers) (Paul Gries (著)、Jennifer Campbell (著)、Jason Montojo (著)、Lynn Beighley (編集)、Pragmatic Bookshelf)のChapter 10(Reading and Writing Files)、10.10(Exercises) 5.をSwiftで考えてみる。
10.10(Exercises) 5.
コード(Xcode)
main.swift
//
// main.swift
// sample5
//
// Created by kamimura on 9/27/14.
// Copyright (c) 2014 kamimura. All rights reserved.
//
import Foundation
func skipHeader(s:String) -> String {
var lines = s.slice(start: s.find("\n") + 1)
while lines.indexAt(0) == "#" {
lines = lines.slice(start: lines.find("\n") + 1)
}
return lines
}
func smallestValue(s:String) -> Int? {
let lines:String = skipHeader(s).strip
if lines != "" {
let lines:[String] = lines.split(sep: "\n").map({(s:String) in s.strip})
var smallest:Int = lines[0].toInt()!
for line in lines.slice(start: 1) {
let value:Int = line.toInt()!
if value < smallest {
smallest = value
}
}
return smallest
}
return nil
}
let s:String = read(argv[1])!
let smallest:Int? = smallestValue(s)
if smallest != nil {
println(smallest!)
}
stdio.swift
//
// stdio.swift
// stdio
//
// Created by kamimura on 8/21/14.
// Copyright (c) 2014 kamimura. All rights reserved.
//
import Foundation
// 標準入力(STDIN)から読み込む
func input(msg:String = "") -> String {
print(msg)
var in_fh = NSFileHandle.fileHandleWithStandardInput()
var data = in_fh.availableData
in_fh.closeFile()
var s = NSString(data: data, encoding: NSUTF8StringEncoding)
s = s?.substringToIndex(s!.length - 1)
return s!
}
func read(path:String) -> String? {
var fh = NSFileHandle(forReadingAtPath: path)
let data = fh?.readDataToEndOfFile()
if fh == nil {
error("file(\(path)) can't open.")
}
fh?.closeFile()
return NSString(data: data!, encoding: NSUTF8StringEncoding)
}
func print(s:String, path:String, end:String = "\n") {
(s + end).writeToFile(path, atomically: true, encoding: NSUTF8StringEncoding, error: nil)
}
func error(msg:String) {
let stderr = NSFileHandle.fileHandleWithStandardError()
stderr.writeData((msg + "\n").dataUsingEncoding(NSUTF8StringEncoding)!)
exit(1)
}
// コマンドライン引数
let argv:[String] = NSProcessInfo.processInfo().arguments.map({(x:AnyObject) -> String in x as String})
string.swift
//
// string.swift
// string
//
// Created by kamimura on 8/10/14.
// Copyright (c) 2014 kamimura. All rights reserved.
//
import Foundation
extension String {
var swapcaseString:String {
var result: String = ""
for ch in self {
let s = String(ch)
result += s.uppercaseString == s ? s.lowercaseString : s.uppercaseString
}
return result
}
var isUpper:Bool { return self.uppercaseString == self }
var isLower:Bool { return self.lowercaseString == self }
var length:Int { return (self as NSString).length }
var strip:String { return self.stringByTrimmingCharactersInSet(NSCharacterSet.whitespaceAndNewlineCharacterSet())}
var floatValue:Float { return (self as NSString).floatValue }
var doubleValue:Double { return (self as NSString).doubleValue }
func count(sub:String) -> Int {
var result:Int = 0
var s = self
let index:String.Index = "a".endIndex
while s != "" {
if s.hasPrefix(sub) {
result += 1
s = s.substringFromIndex(sub.endIndex)
} else {
s = s.substringFromIndex(index)
}
}
return result
}
func find(sub:String, start:Int = 0, end:Int? = nil) -> Int {
var s = self as NSString
var s_temp = s.substringFromIndex(start)
let end_temp:Int = end != nil ? end! : s.length
for i in start..<end_temp {
if (s_temp.hasPrefix(sub)) {
return i
}
s_temp = s.substringFromIndex(i + 1) as NSString
}
return -1
}
func indexAt(i:Int) -> String {
if i >= 0 {
return (self as NSString).substringWithRange(NSRange(location: i, length: 1))
}
let new_i = self.length + i
return (self as NSString).substringWithRange(NSRange(location: new_i, length: 1))
}
func replace(old_str:String, new_str:String) -> String {
return self.stringByReplacingOccurrencesOfString(old_str, withString: new_str)
}
func slice(start:Int=0, end:Int?=nil) -> String {
let s = self as NSString
var new_end:Int
if (end != nil) {
new_end = end!
} else {
new_end = s.length
}
return s.substringWithRange(NSRange(location: start, length:new_end - start))
}
func split(sep:String = "") -> [String] {
var result:[String] = []
if (sep == "") {
for ch in self {
result.append(String(ch))
}
return result
}
var s:String = self
var len = sep.length
var temp:String = ""
while s != "" {
if s.hasPrefix(sep) {
if temp != "" {
result.append(temp)
temp = ""
}
s = s.slice(start: len)
} else {
temp += s.slice(start: 0, end: 1)
s = s.slice(start: 1)
}
}
if temp != "" {
result.append(temp)
}
return result
}
var reversed:String { return "".join(self.split().reverse()) }
func repeat(n:Int) -> String {
var result:String = ""
for i in 0..<n {
result += self
}
return result
}
}
func * (left:String, right:Int) -> String{
return left.repeat(right)
}
func * (left:Int, right:String) -> String{
return right.repeat(left)
}
array.swift
//
// array.swift
// array
//
// Created by kamimura on 8/21/14.
// Copyright (c) 2014 kamimura. All rights reserved.
//
import Foundation
extension Array {
func indexAt(i:Int) -> T {
if i >= 0 {
return self[i]
}
let new_index:Int = self.count + i
return self[new_index]
}
func slice(start:Int = 0, end:Int? = nil) -> Array {
var new_start = start >= 0 ? start : self.count + start
var new_end:Int
if end == nil {
new_end = self.count
} else if end! >= 0 {
new_end = end!
} else {
new_end = self.count + end!
}
var result:Array = []
if new_start >= new_end {
return []
}
for i in new_start..<new_end {
result.append(self[i])
}
return result
}
func forEach(f:(T) -> ()) {
for e in self {
f(e)
}
}
}
func sum(nums:[Int]) -> Int {
return nums.reduce(0, combine: {(x, y) in x + y})
}
func range(start:Int = 0, end:Int, step:Int = 1) -> [Int] {
assert(step != 0, "arg 3 must not be zero")
var result:[Int] = []
var elem = start
if step > 0 {
while elem < end {
result.append(elem)
elem += step
}
} else {
while elem > end {
result.append(elem)
elem += step
}
}
return result
}
入出力結果(Console Output)
$ cat hopedale.txt
22
29
2
16
12
35
8
83
166
$ cat temp.txt
# header
$ ./sample5 hopedale.txt
2
$ ./sample5 temp.txt
$
0 コメント:
コメントを投稿