✨python - flask2 ✨datebase-1

권기찬·2022년 3월 31일

-학습내용-

flask

from flask import Flask, request, redirect


app = Flask(__name__)

topics = [
  {"id":1, "title":"html", "body":"html is ...."},
  {"id":2, "title":"css", "body":"css is ...."},
  {"id":3, "title":"js", "body":"js is ...."}
]
nextId = 4

def template(content, id=None):
  liTags = ''
  for topic in topics:
    liTags = liTags + f'<li><a href="/read/{topic["id"]}/">{topic["title"]}</a></li>'
  return f'''
  <html>
    <body>
      <h1><a href="/">WEB</a></h1>
      <ol>
        {liTags}
      </ol>
      {content}
      <ul>
        <li><a href="/create/">create</a></li>
        <li>
          <form action="/delete/{id}/" method="POST">
            <input type="submit" value="delete">
          </form>
        </li>
      </ul>
    </body>
  </html>
  '''

@app.route("/")
def index():
  return template('<h2>Welcome</h2>Hello, WEB!')

@app.route("/read/<int:id>/")
def read(id):
  title = ''
  body = ''  
  for topic in topics :
    if topic['id'] == id:
      title = topic['title']
      body = topic['body']
      break;
  return template(f'<h2>{title}</h2>{body}', id)

@app.route('/create/')
def create():
  content = '''
    <form action="/create_process/" method="POST">
      <p><input type="text" name="title" placeholder="title"></p>
      <p><textarea name="body" placeholder="body"></textarea></p>
      <p><input type="submit" value="create"></p>
    </form>
  '''
  return template(content)

@app.route('/create_process/', methods=['POST'])
def create_process():
  global nextId
  title = request.form['title']
  body = request.form['body']
  newTopic = {"id":nextId, "title": title, "body": body}
  topics.append(newTopic)
  nextId = nextId + 1
  return redirect(f'/read/{nextId-1}/')


@app.route('/delete/<int:id>/', methods=['POST'])
def delete(id):
  for topic in topics:
    if topic['id'] == id:
      topics.remove(topic)
      break;
  return redirect('/')
 
# @app.route('/update/')
# def update():
#   return 'Update'
 

app.run()

create기능과 delete기능 넣기, method post= 서버에 전송
데이터베이스 맛보기
sqlite를 이용해서 데이터 연동해보기

-문제사항-!

liTags = liTags + f'<li><a href="/read/{topic["id"]}/">{topic["title"]}</a></li>

코드에서 liTags 가 왜 한번 더들어가는 지 모르겠다...

-해결방법-

flask 코드에 주석 다 달아서 잘 이해할 수 있게 재정리하기

-학습소감-

어제 오늘 조금 위기가 왔었지만 강의 영상을 다시보고, 이 코드의 목적에 대해 말하면서 정의내리는 식으로 하니 어느정도 정리가 됬다. 너무 조급한 마음가지지 말고, 내가 하고싶은 목표를 잡고, 천천히 기반을 닦아나가자.

profile
ohmanbanja

0개의 댓글