목차
객체 를 보는 방법은 시리즈에도 적용 가능) " >1. 데이터 보기(객체 를 보는 방법은 시리즈에도 적용 가능)
a.iloc[:,[1, 3] ]=9는 a열과 c열의 모든 행에 있는 값을 9로 설정한다는 의미이기도 합니다
五、合并
分组(groupby)" >六、分组(groupby)
七、Categorical按某一列重新编码分类
八、相关操作
九、时间序列
十、画图(plot)
十一、导入和导出文件
백엔드 개발 파이썬 튜토리얼 Pandas 라이브러리에 도입된 DataFrame의 기본 작업

Pandas 라이브러리에 도입된 DataFrame의 기본 작업

Apr 04, 2017 pm 01:38 PM
python

빈 문자를 삭제목록하는 방법은 무엇입니까?
가장 간단한 방법: new_list = [ x for x in li if x != '' ]


오늘은 5월 1일이다.

이 부분에서는 앞선 두 가지 데이터 구조를 기반으로 팬더의 기본 연산을 주로 연구합니다.

设有DataFrame结果的数据a如下所示:    
       a  b  c
one    4  1  1
two    6  2  0
three  6  1  6
로그인 후 복사

1. 데이터 보기(객체 를 보는 방법은 시리즈에도 적용 가능)

1. 또는 DataFrame 라인 xx
a=DataFrame(data);
a.head(6) 뒤는 head에 매개변수가 없는 경우 데이터의 처음 6개 행을 표시한다는 의미입니다. (), 모든 데이터가 표시됩니다.
a.tail(6)은 데이터의 마지막 6개 행을 표시한다는 의미입니다. tail()에 매개변수가 없으면 모든 데이터가 표시됩니다.

2. DataFrame의 인덱스, 열 및 값을 봅니다.
a.index; a.values; 🎜>3.describe()

함수

빠른 데이터 통계 요약a.describe()는 데이터의 각 열(개수, 평균, 표준점, 각 분위수 등)에 대한 통계를 수행합니다. .
4. 데이터 전치

a.T
5. 축 정렬

a. _index(axis=1,ascend
ing=False);여기서 axis=1은 의 모든 열 정렬을 의미하며 다음 숫자도 이에 따라 이동합니다. 다음 ascending=False는 내림차순으로 정렬한다는 의미이며, 매개변수가 누락된 경우 기본값은 오름차순입니다.
6. DataFrame의 값을 정렬합니다.

a.sort(columns='x')

즉, a의 x 열을 작은 것부터 정렬합니다. 크기가 큰 . x 열만 해당되며 위의 축별 정렬은 모든 열에 대해 작동합니다. 2. 객체 선택

1. 특정 열과 행의 데이터를 선택합니다.

a['x'] 그러면 열이 x인 열은 반환됨,

이 메서드는 한 번에 하나의 열만 반환할 수 있습니다. a.x는 a['x']와 같은 의미입니다.
행 데이터를 가져오고 []를 분할하여 을 선택합니다. 예를 들어 a[0:3]은 처음 세 행의 데이터를 반환합니다.

2.loc는 태그를 통해 데이터를 선택합니다.

a.loc['one']은 기본적으로

동작 'one'이 있는 행이 선택되었음을 나타냅니다. ;
a.loc[:,['a','b'] ]는 열이 a와 b인 모든 행과 열을 선택하는 것을 의미합니다. a.loc[['one' ,'two'],['a','b']]는 'one'과 'two'라는 두 행과 a와 b인 열을 선택하는 것을 의미합니다.

a.loc['one; ' ,'a'] 는 a.loc[['one'],['a']] 와 동일한 효과를 가지지만 전자는 해당 값만 표시하고 후자는 해당 행 및 열 레이블을 표시합니다.

3.iloc은 위치별로 직접 데이터를 선택합니다

레이블별로 선택하는 것과 비슷합니다

a.iloc[1:2,1:2]가 표시됩니다. 첫 번째 행과 첫 번째 열에서; (슬라이스 이후의 값을 얻을 수 없음) a.iloc[1:2]는 후속 열에 값이 없을 때
행을 의미합니다. position은 기본적으로 1로 선택되어 있습니다. data
;

a.iloc[[0,2],[1,2]]는 행 위치와 열 위치에 해당하는 데이터를 자유롭게 선택할 수 있다는 의미입니다. .

4. 조건을 사용하여 선택

별도의 열을 사용하여 데이터 선택 a[a.c>0]은 c 열 선택을 의미합니다. 0보다 큼
데이터 선택 위치 사용a[a>0] 테이블에서 0보다 큰 모든 데이터를 직접 선택

isin()을 사용하여 특정

행 선택

a1=a.

copy()a1[a1['one'].isin(['2','3']) 열에 특정 값이 포함되어 있음 ] 표에는 조건을 충족하는 모든 행이 표시됩니다. 첫 번째 열의 값에는 '2', '3'이 포함됩니다.
3. 설정값(할당)
위의 선택 연산을 바탕으로 할당 연산을 직접 할당할 수 있습니다.

예 a.loc[:,['a','c']]=9는 a 및 c 열의 모든 행에 있는 값을 9로 설정한다는 의미입니다

a.iloc[:,[1, 3] ]=9는 a열과 c열의 모든 행에 있는 값을 9로 설정한다는 의미이기도 합니다

동시에 조건을 사용하여 값을 직접 할당할 수도 있습니다
a[ a>0]=-a 에 a를 설정한다는 의미 0보다 큰 모든 숫자는 음수값으로 변환됩니다. ​​

4. 누락된 값 처리


pandas에서는 np.nan을 사용하여 교체합니다. 누락된 값은 기본적으로 계산에 포함되지 않습니다.

1.reindex() 메소드

는 지정된 축

인덱스
변경/추가/삭제하는 데 사용됩니다. 원본 데이터의 사본이 반환됩니다. a.reindex(index=list(a.index)+['five'],columns=list(a.columns)+['d'])

a.reindex(index=['one','five'],columns=list(a.columns)+['d'])

即用index=[]表示对index进行操作,columns表对列进行操作。

2.对缺失值进行填充
a.fillna(value=x)
表示用值为x的数来对缺失值进行填充

3.去掉包含缺失值的行
a.dropna(how='any')
表示去掉所有包含缺失值的行

五、合并

1.contact
contact(a1,axis=0/1,
keys=['xx','xx','xx',...]),其中a1表示要进行进行连接的列表数据,axis=1时表横着对数据进行连接。axis=0或不指定时,表将数据竖着进行连接。a1中要连接的数据有几个则对应几个keys,设置keys是为了在数据连接以后区分每一个原始a1中的数据。

例:a1=[b['a'],b['c']]
result=pd.concat(a1,axis=1,keys=['1','2'])

2.Append 将一行或多行数据连接到一个DataFrame上
a.append(a[2:],ignore_index=True)
表示将a中的第三行以后的数据全部添加到a中,若不指定ignore_index参数,则会把添加的数据的index保留下来,若ignore_index=Ture则会对所有的行重新自动建立索引。

3.merge类似于SQL中的join
设a1,a2为两个dataframe,二者中存在相同的键值,两个对象连接的方式有下面几种:
(1)内连接,pd.merge(a1, a2, on='key')
(2)左连接,pd.merge(a1, a2, on='key', how='left')
(3)右连接,pd.merge(a1, a2, on='key', how='right')
(4)外连接, pd.merge(a1, a2, on='key', how='outer')
至于四者的具体差别,具体学习参考sql中相应的语法。

六、分组(groupby)

用pd.date_range函数生成连续指定天数的的日期
pd.date_range('20000101',periods=10)

def shuju():
    data={
        'date':pd.date_range('20000101',periods=10),
        'gender':np.random.randint(0,2,size=10),
        'height':np.random.randint(40,50,size=10),
        'weight':np.random.randint(150,180,size=10)
    }
a=DataFrame(data)
print(a)
        date  gender  height  weight
0 2000-01-01       0      47     165
1 2000-01-02       0      46     179
2 2000-01-03       1      48     172
3 2000-01-04       0      45     173
4 2000-01-05       1      47     151
5 2000-01-06       0      45     172
6 2000-01-07       0      48     167
7 2000-01-08       0      45     157
8 2000-01-09       1      42     157
9 2000-01-10       1      42     164

用a.groupby('gender').sum()得到的结果为:  #注意在python中groupby(''xx)后要加sum(),不然显示
不了数据对象。
gender     height  weight               
0           256     989
1           170     643
로그인 후 복사

此外用a.groupby('gender').size()可以对各个gender下的数目进行计数。

所以可以看到groupby的作用相当于:
按gender对gender进行分类,对应为数字的列会自动求和,而为字符串类型的列则不显示;当然也可以同时groupby(['x1','x2',...])多个字段,其作用与上面类似。

七、Categorical按某一列重新编码分类

如六中要对a中的gender进行重新编码分类,将对应的0,1转化为male,female,过程如下:

a['gender1']=a['gender'].astype('category')
a['gender1'].cat.categories=['male','female']  #即将0,1先转化为category类型再进行编码。

 print(a)得到的结果为:
      date    gender  height  weight gender1
0 2000-01-01       1      40     163  female
1 2000-01-02       0      44     177    male
2 2000-01-03       1      40     167  female
3 2000-01-04       0      41     161    male
4 2000-01-05       0      48     177    male
5 2000-01-06       1      46     179  female
6 2000-01-07       1      42     154  female
7 2000-01-08       1      43     170  female
8 2000-01-09       0      46     158    male
9 2000-01-10       1      44     168  female
로그인 후 복사

所以可以看出重新编码后的编码会自动增加到dataframe最后作为一列。

八、相关操作

描述性统计:
1.a.mean()  默认对每一列的数据求平均值;若加上参数a.mean(1)则对每一行求平均值;

2.统计某一列x中各个值出现的次数:a['x'].value_counts();

3.对数据应用函数
a.apply(lambda x:x.max()-x.min())
表示返回所有列中最大值-最小值的差。

4.字符串相关操作
a['gender1'].str.lower()  将gender1中所有的英文大写转化为小写,注意dataframe没有str属性,只有series有,所以要选取a中的gender1字段。

九、时间序列

在六中用pd.date_range('xxxx',periods=xx,freq='D/M/Y....')函数生成连续指定天数的的日期列表。
例如pd.date_range('20000101',periods=10),其中periods表示持续频数;
pd.date_range('20000201','20000210',freq='D')也可以不指定频数,只指定起始日期。

此外如果不指定freq,则默认从起始日期开始,频率为day。其他频率表示如下:

Pandas 라이브러리에 도입된 DataFrame의 기본 작업

1.png

十、画图(plot)

在pycharm中首先要:import matplotlib.pyplot as plt
a=Series(np.random.randn(1000),index=pd.date_range('20100101',periods=1000))
b=a.cumsum()
b.plot()
plt.show()    #最后一定要加这个plt.show(),不然不会显示出图来。
로그인 후 복사

Pandas 라이브러리에 도입된 DataFrame의 기본 작업

2.PNG


也可以使用下面的代码来生成多条时间序列图:

a=DataFrame(np.random.randn(1000,4),index=pd.date_range('20100101',periods=1000),columns=list('ABCD'))
b=a.cumsum()
b.plot()
plt.show()
로그인 후 복사

Pandas 라이브러리에 도입된 DataFrame의 기본 작업

3.png

十一、导入和导出文件

写入和读取excel文件
虽然写入excel表时有两种写入xls和csv,但建议少使用csv,不然在表中调整数据格式时,保存时一直询问你是否保存新格式,很麻烦。而在读取数据时,如果指定了哪一张sheet,则在pycharm又会出现格式不对齐。

还有将数据写入表格中时,excel会自动给你在表格最前面增加一个字段,对数据行进行编号。

a.to_excel(r'C:\\Users\\guohuaiqi\\Desktop\\2.xls',sheet_name='Sheet1')    

a=pd.read_excel(r'C:\\Users\\guohuaiqi\\Desktop\\2.xls','Sheet1',na_values=['NA'])

注意sheet_name后面的Sheet1中的首字母大写;读取数据时,可以指定读取哪一张表中的数据,而
且对缺失值补上NA。

最后再附上写入和读取csv格式的代码:
a.to_csv(r'C:\\Users\\guohuaiqi\\Desktop\\1.csv',sheet_name='Sheet1')
a=pd.read_csv(r'C:\\Users\\guohuaiqi\\Desktop\\1.csv',na_values=['NA'])
로그인 후 복사

       

위 내용은 Pandas 라이브러리에 도입된 DataFrame의 기본 작업의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

C 언어 합계의 기능은 무엇입니까? C 언어 합계의 기능은 무엇입니까? Apr 03, 2025 pm 02:21 PM

C 언어에는 내장 합계 기능이 없으므로 직접 작성해야합니다. 합계는 배열 및 축적 요소를 가로 질러 달성 할 수 있습니다. 루프 버전 : 루프 및 배열 길이를 사용하여 계산됩니다. 포인터 버전 : 포인터를 사용하여 배열 요소를 가리키며 효율적인 합계는 자체 증가 포인터를 통해 달성됩니다. 동적으로 배열 버전을 할당 : 배열을 동적으로 할당하고 메모리를 직접 관리하여 메모리 누출을 방지하기 위해 할당 된 메모리가 해제되도록합니다.

누가 더 많은 파이썬이나 자바 스크립트를 지불합니까? 누가 더 많은 파이썬이나 자바 스크립트를 지불합니까? Apr 04, 2025 am 12:09 AM

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

XML을 MP3로 변환하는 방법 XML을 MP3로 변환하는 방법 Apr 03, 2025 am 09:00 AM

XML을 MP3로 변환하는 단계에는 다음이 포함됩니다. XML에서 오디오 데이터 추출 : XML 파일을 구문 분석하고, 오디오 데이터가 포함 된 Base64 인코딩 문자열을 찾아 이진 형식으로 디코딩하십시오. 오디오 데이터를 MP3로 인코딩합니다. MP3 인코더를 설치하고 인코딩 매개 변수를 설정하고 이진 오디오 데이터를 MP3 형식으로 인코딩 한 다음 파일에 저장하십시오.

별개의 구별이 관련되어 있습니까? 별개의 구별이 관련되어 있습니까? Apr 03, 2025 pm 10:30 PM

구별되고 구별되는 것은 구별과 관련이 있지만, 다르게 사용됩니다. 뚜렷한 (형용사)는 사물 자체의 독창성을 묘사하고 사물 사이의 차이를 강조하는 데 사용됩니다. 뚜렷한 (동사)는 구별 행동이나 능력을 나타내며 차별 과정을 설명하는 데 사용됩니다. 프로그래밍에서 구별은 종종 중복 제거 작업과 같은 컬렉션에서 요소의 독창성을 나타내는 데 사용됩니다. 홀수 및 짝수 숫자를 구별하는 것과 같은 알고리즘이나 함수의 설계에 별개가 반영됩니다. 최적화 할 때 별도의 작업은 적절한 알고리즘 및 데이터 구조를 선택해야하며, 고유 한 작업은 논리 효율성의 구별을 최적화하고 명확하고 읽을 수있는 코드 작성에주의를 기울여야합니다.

XML 형식을 변경하는 방법 XML 형식을 변경하는 방법 Apr 03, 2025 am 08:42 AM

XML 형식을 수정하는 방법에는 여러 가지가 있습니다. Notepad와 같은 텍스트 편집기로 수동으로 편집; XMLBeautifier와 같은 온라인 또는 데스크탑 XML 서식 도구와 자동 포맷; XSLT와 같은 XML 변환 도구를 사용하여 변환 규칙을 정의합니다. 또는 Python과 같은 프로그래밍 언어를 사용하여 구문 분석하고 작동합니다. 원본 파일을 수정하고 백업 할 때주의하십시오.

XML에서 데이터를 수정하는 방법 XML에서 데이터를 수정하는 방법 Apr 03, 2025 am 08:12 AM

XML 데이터 수정은 수동으로 수행하거나 프로그래밍 언어 및 라이브러리를 사용하여 수행 할 수 있습니다. 수동 수정은 요소 및 속성 추가, 수정 또는 삭제를 포함하여 작은 문서에 대한 소량의 수정에 적합합니다. 보다 복잡한 수정, Python 's XML.Dom 및 Java's Javax.xml.parsers와 같은 프로그래밍 언어 및 라이브러리를 위해 XML 데이터를 처리하는 도구를 제공합니다. XML 데이터를 수정할 때 유효성을 확인하고 백업을 생성하며 올바른 태그 및 속성을 포함하여 XML 구문 규칙을 따르십시오.

XML을 Word로 변환하는 방법 XML을 Word로 변환하는 방법 Apr 03, 2025 am 08:15 AM

XML을 Word로 변환하는 세 가지 방법이 있습니다. Microsoft Word를 사용하거나 XML 변환기를 사용하거나 프로그래밍 언어를 사용하십시오.

이해하는 방법! x는? 이해하는 방법! x는? Apr 03, 2025 pm 02:33 PM

! x 이해! x는 C 언어로 된 논리적 비 운영자입니다. 그것은 x의 값, 즉 실제 변경, 거짓, 잘못된 변경 사항을 부수합니다. 그러나 C의 진실과 거짓은 부울 유형보다는 숫자 값으로 표시되며, 0이 아닌 것은 참으로 간주되며 0만이 거짓으로 간주됩니다. 따라서! x는 음수를 양수와 동일하게 처리하며 사실로 간주됩니다.

See all articles