찾다
백엔드 개발파이썬 튜토리얼Python Python에서 MYSQL 사용하기

이유

최근에 저는 온라인 페이지를 크롤링하는 데 필요한 작은 도구를 작업하고 있습니다. 그런 다음 구문 분석하십시오. 결과를 데이터베이스에 넣습니다.

저는 이 분야에 Python이 장점이 있다는 것을 알고 선택했습니다.

서버에 mysql이 설치되어 있어서 자연스럽게 사용하게 되네요. 데이터베이스를 운영하면서 많은 문제가 발생했습니다. 여러분의 상호 격려를 위해 여기에 기록하겠습니다.

Python에서 mysql 호출

Baidu는 MySQLdb를 통해 데이터베이스 작업을 수행할 수 있습니다. 설명서를 확인하고 Python이 mysql의 c 언어 API를 직접 구현하는 mysql을 제공한다는 것을 알아보세요. MySQLdb는 더 높은 수준의 캡슐화이므로 사용하기가 더 편리합니다. mysql을 사용할 수도 있지만 더 좋은 방법은 MySQLdb를 사용하는 것입니다.

설치 중 발생하는 문제

http://sourceforge.net/projects/mysql-python/ 페이지에서 다운로드할 수 있습니다. 최신 버전의 MySQLdb의 경우, 압축 해제 후 설치 실행 시 일부 문제가 발생할 수 있습니다.

Python setup.py 빌드를 통해 설치를 실행하면 No module name setuptools라는 메시지가 표시됩니다

해결 방법, 설치

sudo apt-get install python-setuptools

다시 실행해도 여전히 mysql_config를 찾을 수 없다는 오류가 발생할 수 있습니다

이때 mysqld-dev를 설치해야 합니다

sudo apt-get install libmysqld-dev

다시 실행하면 계속 발생할 수 있습니다. 오류가 발생했습니다. 이와 같은 `

Building 'mysql' 확장 gcc -pthread -fno-strict-aliasing -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -fPIC -Dversion_info=(1,2,3, ' 최종',0) -Dversion=1.2.3 -I/usr/include/mysql -I/usr/include/python2.7 -c mysql.c -o build/temp.linux-i686-2.7/mysql.o - DBIG_JOINS=1 -fno-strict-aliasing -DUNIV_LINUX -DUNIV_LINUX mysql.c:29:0에 포함된 파일: pymemcompat.h:10:20: 치명적인 오류: Python.h: 해당 파일 또는 디렉터리가 없습니다

솔루션

sudo apt-get install python-dev

이 단계는 Python용 개발 헤더 파일을 설치하는 단계입니다.

기본적으로 처음 세 가지 방법 이후에는 다른 문제가 발생하지 않습니다.

단, mysql은 직접 설치했다고 가정하겠습니다. 또한, lib 파일이 /usr/local/lib 아래에 위치하지 않으면 오류가 보고됩니다.

해결 방법은 파일을 이 폴더에 소프트 링크하거나 시스템의 /etc/ld.so.cnf 파일을 수정하고 lib가 있는 폴더를 배치하는 것입니다. 두 가지 방법 모두 작동합니다. 그런 다음 ldconfig에서 적용되도록 하십시오.

예를 들어 첫 번째 방법인 ln -s /usr/local/mysql/lib/mysql/libmysqlclient* /usr/lib

실제 사용

을 소개합니다. MySQLdb 라이브러리

MySQLdb 가져오기

데이터베이스에 연결

conn=MySQLdb.connect(host="localhost",user="root",passwd="sa",db ="mytable ",charset="utf8")

제공된 연결 메소드는 데이터베이스와의 연결을 설정하는 데 사용되며 여러 매개변수를 수신하고 연결 개체를 반환합니다.

명령문을 실행합니다. 결과를 얻습니다

Cursor=conn.cursor() n=cursor.execute(sql,param)

먼저 연결 객체를 사용하여 커서 객체를 얻습니다. 커서가 제공하는 메서드를 사용하여 작업합니다. 이 메서드에는 두 가지 주요 범주가 있습니다: 1. 명령 실행, 2. 반환 값 수신

이에 대해서는 나중에 자세히 설명하겠습니다. 여기서는 알 수 없음

끝. 데이터베이스 연결 닫기

포인터 개체와 연결 개체를 별도로 닫아야 합니다.

Cursor.close()

conn.close라는 이름의 메서드가 있습니다. ()

자주 사용하는 작업 API

트랜잭션 작업 지원, 표준 메서드 commit() submit

rollback()rollback

커서가 사용하는 메서드 실행 명령:

callproc(self, procname, args): 저장 프로시저를 실행하는 데 사용되는 매개변수는 저장 프로시저 이름과 매개변수 목록이며, 반환 값은 영향을 받는 행의 수입니다.

실행( self, query, args): 수신된 매개변수는 SQL 문 자체이며 반환 값은 영향을 받은 행의 수입니다.

executemany(self , query, args): 단일 SQL 문을 실행하지만 매개변수 목록의 매개변수를 반복적으로 실행하고 반환 값은 영향을 받은 행 수입니다. nextset(self): 다음 결과 집합으로 이동

메서드 반환 값을 받기 위해 커서에 사용됩니다.

fetchall(self): 반환된 모든 결과 행을 받습니다.

fetchmany(self, size=None): 크기 반환 결과 행을 받습니다. size 값이 반환된 결과 행보다 큽니다.

fetchone(self):

스크롤(self, value, mode='relative'): 포인터를 특정 행으로 이동합니다. mode='relative'인 경우 현재 행에서 값 막대를 이동한다는 의미입니다. mode='absolute'인 경우 첫 번째 행에서 값 막대를 이동한다는 의미입니다.

끝에 문장 삽입: 🎜>

컴퓨터가 ubuntu14.04로 업그레이드되고 다시 설치되었습니다. 이전 블로그 저장소가 사라지고 github에서 다시 가져왔습니다. 문제가 발생했습니다. 파일을 삭제했더니 이 글이 거의 없어졌습니다. 이제라도 이 글을 읽을 수 있어서 다행이다.


성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Numpy를 사용하여 다차원 배열을 어떻게 생성합니까?Numpy를 사용하여 다차원 배열을 어떻게 생성합니까?Apr 29, 2025 am 12:27 AM

다음 단계를 통해 Numpy를 사용하여 다차원 배열을 만들 수 있습니다. 1) Numpy.array () 함수를 사용하여 NP.Array ([[1,2,3], [4,5,6]]과 같은 배열을 생성하여 2D 배열을 만듭니다. 2) np.zeros (), np.ones (), np.random.random () 및 기타 함수를 사용하여 특정 값으로 채워진 배열을 만듭니다. 3) 서브 어레이의 길이가 일관되고 오류를 피하기 위해 배열의 모양과 크기 특성을 이해하십시오. 4) NP.Reshape () 함수를 사용하여 배열의 모양을 변경하십시오. 5) 코드가 명확하고 효율적인지 확인하기 위해 메모리 사용에주의를 기울이십시오.

Numpy 어레이에서 '방송'의 개념을 설명하십시오.Numpy 어레이에서 '방송'의 개념을 설명하십시오.Apr 29, 2025 am 12:23 AM

BroadcastingInnumpyIsamethodtoperformoperationsonArraysoffferentShapesByAutomicallyAligningThem.itsimplifiesCode, enourseadability, andboostsperformance.here'showitworks : 1) smalraysarepaddedwithonestomatchdimenseare

데이터 저장을 위해 목록, Array.Array 및 Numpy Array 중에서 선택하는 방법을 설명하십시오.데이터 저장을 위해 목록, Array.Array 및 Numpy Array 중에서 선택하는 방법을 설명하십시오.Apr 29, 2025 am 12:20 AM

forpythondatastorage, chooselistsforflexibilitywithmixeddatatypes, array.arrayformemory-effic homogeneousnumericaldata, andnumpyarraysforadvancednumericalcomputing.listsareversatilebutlessefficipforlargenumericaldatasets.arrayoffersamiddlegro

파이썬 목록을 사용하는 것이 배열을 사용하는 것보다 더 적절한 시나리오의 예를 제시하십시오.파이썬 목록을 사용하는 것이 배열을 사용하는 것보다 더 적절한 시나리오의 예를 제시하십시오.Apr 29, 2025 am 12:17 AM

pythonlistsarebetterthanarraysformanagingDiversEdatatypes.1) 1) listscanholdementsofdifferentTypes, 2) thearedynamic, weantEasyAdditionSandremovals, 3) wefferintufiveOperationsLikEslicing, but 4) butiendess-effectorlowerggatesets.

파이썬 어레이에서 요소에 어떻게 액세스합니까?파이썬 어레이에서 요소에 어떻게 액세스합니까?Apr 29, 2025 am 12:11 AM

toaccesselementsInapyThonArray : my_array [2] AccessHetHirdElement, returning3.pythonuseszero 기반 인덱싱 .1) 사용 positiveAndnegativeIndexing : my_list [0] forthefirstelement, my_list [-1] forstelast.2) audeeliciforarange : my_list

파이썬에서 튜플 이해력이 가능합니까? 그렇다면, 어떻게 그리고 그렇지 않다면?파이썬에서 튜플 이해력이 가능합니까? 그렇다면, 어떻게 그리고 그렇지 않다면?Apr 28, 2025 pm 04:34 PM

기사는 구문 모호성으로 인해 파이썬에서 튜플 이해의 불가능성에 대해 논의합니다. 튜플을 효율적으로 생성하기 위해 튜플 ()을 사용하는 것과 같은 대안이 제안됩니다. (159 자)

파이썬의 모듈과 패키지는 무엇입니까?파이썬의 모듈과 패키지는 무엇입니까?Apr 28, 2025 pm 04:33 PM

이 기사는 파이썬의 모듈과 패키지, 차이점 및 사용법을 설명합니다. 모듈은 단일 파일이고 패키지는 __init__.py 파일이있는 디렉토리이며 관련 모듈을 계층 적으로 구성합니다.

파이썬에서 Docstring이란 무엇입니까?파이썬에서 Docstring이란 무엇입니까?Apr 28, 2025 pm 04:30 PM

기사는 Python의 Docstrings, 사용법 및 혜택에 대해 설명합니다. 주요 이슈 : 코드 문서 및 접근성에 대한 문서의 중요성.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구