๋ชฉ๋ก์ ์ฒด ๊ธ (1103)
KoreanFoodie's Study
data:image/s3,"s3://crabby-images/e2426/e24269c9cb0a11a3b6412adced4795f803c56df8" alt=""
์ค์นผ๋ผ ํํ ๋ฆฌ์ผ, scala datatypes part2 Pattern Matching A way to use algebraic datatypes Syntax: e match { case C1(...) => e1 ... case Cn(...) => en } Example : sealed abstract class IList case class INil() extends IList case class ICons(hd: Int, tl: IList) extends IList def x: IList = ICons(2, ICons(1, INil())) def length(xs: IList) : Int = xs match { case INil() => 0 case ICons(x, tl) => 1 + length(t..
data:image/s3,"s3://crabby-images/92137/92137f142aa1d6a418860646f4899c7b0f9fc52b" alt=""
์ค์นผ๋ผ ํํ ๋ฆฌ์ผ, scala์ datatypes์ ๋ํด ์์๋ณด์ Types in general Introdection : How to construct elements Elimination : How to use elements of the type Primitive types : Int, Boolean, Double, String... Intro for Int: ...,-2,-1,0,1,2 Elim for Int: +,-,*,/... -Function types : Int => Int, (Int => Int)=>(Int => Int) Intro: (x:T)=>e Elim: f(v) Tuples Intro : (1, 2, 3) : (Int, Int, Int) (1, "a") : (Int, String) ..
data:image/s3,"s3://crabby-images/58bfd/58bfd8040b81a8f72e2fc3f83fd55a8d478f2394" alt=""
์ค์นผ๋ผ ํํ ๋ฆฌ์ผ, scala์์ currying์ ๋ํด ์์๋ณด์ Currying Why we use currying? Let's look at the code, simplified by currying. def sum(f: Int=>Int, a: Int, b: Int): Int = if (a Int): (Int, Int) => Int = { def sumF(a: Int, b: Int): Int = if (a Int)(a: Int, b: Int): Int = if (a T can be turned into one of type T1 => (T2 => (... Tn =>T) This is called 'currying' named after Haskell Brooks Curry. The opposite di..
data:image/s3,"s3://crabby-images/5c9bf/5c9bfa05fc03f63f0adf92f0b09ef0afd87657a2" alt=""
์ค์นผ๋ผ ํํ ๋ฆฌ์ผ, scala์ closure์ ๋ํด ์์๋ณด์ Parameterized expression vs. values Functions defined using “def” are not values but parameterized expressions. • Anonymous functions are values. • But, parameterized expressions are implicitly converted to values. • Explicit conversion: f _ • Anonymous functions can be seen as syntactic sugar: (x:T)=>e is equivalent to { def \_\_noname(x:T) = e; \_\_noname \_ }..
data:image/s3,"s3://crabby-images/2e9ea/2e9ea7fbecbc341b854909aae772cdb0c0aa460f" alt=""
์ค์นผ๋ผ ํํ ๋ฆฌ์ผ, scala์ tail recursion์ ์์๋ด ์๋ค Recursion needs care Let's look at typical summation fuction. def sum(n: Int) : Int = if (n x*x*x, n) // or def sumLinear(n: Int) = sum((x)=>x, n) def sumSquare(n: Int) = sum((x)=>x*x, n) def sumCubes(n: Int) = sum((x)=>x*x*x, n) Excercise def sum(f: Int => Int, a: Int, b: Int): Int = if (a Int, a: Int, b: Int): Int = if (a Int, inival: Int, f: Int => Int, ..
data:image/s3,"s3://crabby-images/86c08/86c08a6f525af8d49d99801bd9f6d5175a33b542" alt=""
์ค์นผ๋ผ ํํ ๋ฆฌ์ผ, scala์์ lazy val์ ๋ํด ์์๋ณด์ Blocks and Name Scoping Blocks in scala Block is an expression. It also allow nested name binding. Block allows arbitraty order of "def"s, but not "val"s(think about why). Scope of names Block example : val t = 0 def f(x: Int) = t + g(x) def g(x: Int) = x * x val x = f(5) val r = { val t = 10 val s = f(5) t + s } val y = t + r A definition inside a block is on..
data:image/s3,"s3://crabby-images/3c7eb/3c7eb5b89ab6e523133336b1f233be28ac6f3a57" alt=""
์ค์นผ๋ผ์์ call by value์ call by name์ ์ฐจ์ด๋ฅผ ์์๋ณด์ There is two strategy to evaluate values. Call-by-value Evaluate the arguments first, then apply the function to them Call-by-name Just apply the function to its arguments, without evaluating them Let's see the example. def square (x: Int) = x * x [cbv] square(1+1) ~ square(2) ~ 2 * 2 ~ 4 [cbn] square(1+1) ~ (1+1) * (1+1) ~ 2 * (1+1) ~ 2 * 2 ~ 4 So wha..
data:image/s3,"s3://crabby-images/8f012/8f0121dd4bdd73446be98bd4a6006f171111e697" alt=""
ํ์ด์ฌ์ผ๋ก ๋ง๋ ๊ฐ๋จํ ํฌ๋กค๋ฌ ์ฐธ๊ณ ์๋ฃ : ์น ํฌ๋กค๋ฌ ๋ง๋ค๊ธฐ, Implicit vs. Explict wait ๋น๊ตํ๊ธฐ ์ ํฌ๋ธ์์ ์์ ๋ค์ด๋ก๋ํ๋ ์์ ์๋ํ ํ๊ธฐ ์น๊ตฌ๊ฐ ์ ํฌ๋ธ๋ฅผ ํตํด ์์ ์ ๋ณํํด์ ๋ค์ด๋ก๋ ๋ฐ๋ ๊ฒ์ ๋ณด๊ณ , ์ด๋ฅผ ๊ฐํธํ๊ฒ ํด์ฃผ๊ณ ์ ํ์ด์ฌ selenium module, chromedriver์ ์ด์ฉํด ์คํํค(Win+R)๋ฅผ ํตํด ์ฝ๊ฒ ์์ ์ ๋ค์ด๋ก๋ํ๋ ์ฝ๋๋ฅผ ์์ฑํด ๋ณด์์ต๋๋ค. ์, ์ฐธ๊ณ ๋ก mp3juices.cc ๋ผ๋ ์ฌ์ดํธ๋ก๋ถํฐ ์์ ์ ๋ณํํด์ ๋ค์ด์ ํ๋๋ฐ, ์ฌ๊ธฐ๊ฐ ์ ์ผ ๊น๋ํ ๊ฒ ๊ฐ์์(์ ๊ธฐ์ค) Prerequsite : Python3 (Latest version is recommemded) Installing 3rd party modules (pyperclip, seleniu..
data:image/s3,"s3://crabby-images/12722/127227a1ee021bd536704a4c8df5345e80a59b7d" alt=""
ํ์ด์ฌ์์ ๊น๋จน์ ์ ์๋ ์์ํ ์ฌํญ๋ค์ ๋ฆฌ๋ง์ธ๋ํ๋ ํฌ์คํธ์ ๋๋ค. ์ฝ๋๋ค์ automatetheboringstuff.com์์ ์ฐธ์กฐํ์ต๋๋ค. ์ ์์ Backslash on Windows and Forward Slash on OS X and Linux >>> import os >>> os.path.join('usr', 'bin', 'spam') 'usr\\bin\\spam' The os.path.join() function is helpful if you need to create strings for filenames. These strings will be passed to several of the file-related functions introduced in this chapter. For..
data:image/s3,"s3://crabby-images/cba72/cba723c98790daa8fe429604689d74d787a1e5f5" alt=""
ํ์ด์ฌ์์ ๊น๋จน์ ์ ์๋ ์์ํ ์ฌํญ๋ค์ ๋ฆฌ๋ง์ธ๋ํ๋ ํฌ์คํธ์ ๋๋ค. ์ฝ๋๋ค์ automatetheboringstuff.com์์ ์ฐธ์กฐํ์ต๋๋ค. ์ ์์ Raw Strings A raw string completely ignores all escape characters and prints any backslash that appears in the string. >>> print(r'That is Carol\'s cat.') That is Carol\'s cat. Slicing strings >>> spam = 'Hello world!' >>> spam[0] 'H' >>> spam[4] 'o' >>> spam[-1] '!' >>> spam[0:5] 'Hello' >>> spam[:5] 'Hello' >..