《利用Python进行数据分析》数据处理——MovieLens 1M数据集

2023-10-31 08:50

本文主要是介绍《利用Python进行数据分析》数据处理——MovieLens 1M数据集,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MovieLens 1M数据集下载地址:https://grouplens.org/datasets/movielens/1m/

为方便,我已将数据集防止在csdn上,方便下载。

地址:https://download.csdn.net/download/m0_52945258/20415963?spm=1001.2014.3001.5501

read_table

read_table是一个数据读入工具,将数据读入到一个DataFrame中,例如,在本次数据处理的例子中,我们先
import pandas as pduname = ['user_id', 'gender', 'age', 'occupation', 'zip']
users = pd.read_table(r'ml-1m\users.dat', sep='::', header=None, names=uname,engine='python')

sep=' ':表示的是分隔符,比如说,在这个例子中,原数据集是以::来分隔的,所以我们的分隔符是'::',如果是txt文件,则我们的分隔符是制表符,‘\t’

header=None 表示txt文件的第一行不是列的名字,是数据。如果你的数据集一开始的第一列是数据名称,则不需要加这个,如果不是,则需要表示出来没有标题。

names表示这个DataFrame的标题是什么

运行结果:

 如果是需要处理txt文件,具体查看博客:https://blog.csdn.net/u014453898/article/details/86601224

merge

data=pd.merge(pd.merge(ratings,users),movies)

将多个表合并。

pivot_table

mean_ratings = data.pivot_table(values ='rating', index='title', columns ='gender', aggfunc='mean')

pivot_table具体用法可以查看博客:https://www.cnblogs.com/Yanjy-OnlyOne/p/11195621.html

写的超级好)

pivot_table( values=None, index=None, columns=None,aggfunc='mean')

主要的四个参数分别是values, index, columns, aggfunc

index表示索引,可以表示为标题吧(行标)

如果想要用两个索引值,就需要将索引用一个中括号阔起来,比如

df=pd.pivot_table(data,index=['  ','  '])

Values可以对需要的计算数据进行筛选

columns相当于对列进行索引、分类,和index差不多(列标)

aggfunc相当于是我们对数据聚合的操作,取平均数

groupby

具体用法请看博文:https://www.yiibai.com/pandas/python_pandas_groupby.html

主要就是通过后面的内容对数据进行分组

loc

数据选取函数,主要用法见博文:https://www.jianshu.com/p/1115699e0674

选取符合的数据


mean_ratings = mean_ratings.loc[active_titles]

sort_values

  • DataFrame.sort_values(by=‘##’,axis=0,ascending=True, inplace=False, na_position=‘last’)

 主要用到by和ascending

by:指定列名(axis=0或’index’)或索引值(axis=1或’columns’)

ascending:是否按指定列的数组升序排列,默认为True,即升序排列

在本题中的应用

top_female_ratings=mean_ratings.sort_values(by='F',ascending=False)

之后,我们想要查看男女分歧最大的电影,所以我们需要在mean_rateings中间加入一行,表示男女分数的平均差,加入和排序方式如下:


mean_ratings['diff'] = mean_ratings['M'] - mean_ratings['F']
sort_by_diff = mean_ratings.sort_values(by='diff')

想要得到男生最喜欢的电影,则需要对这个这个进行逆向排序

print(sort_by_diff[::-1][:3])

最后,得到所以人分歧最大的电影,则

rating_std = data.groupby('title')['rating'].size()
print(rating_std)
rating_std = rating_std.loc[active_titles]
sorted_rating_std=rating_std.sort_values(ascending=False)

完整代码:


 

# coding=gbkimport pandas as pduname = ['user_id', 'gender', 'age', 'occupation', 'zip']
users = pd.read_table(r'ml-1m/users.dat', sep='::', header=None, names=uname, engine='python')
#print(users)
rnames = ['user_id', 'movie_id', 'rating', 'timestamp']
ratings = pd.read_table(r'ml-1m/ratings.dat', header=None, sep='::', names=rnames, engine='python')mnames = ['movie_id', 'title', 'genres']
movies = pd.read_table(r'ml-1m/movies.dat', header=None, sep='::', names=mnames, engine='python')data=pd.merge(pd.merge(ratings,users),movies)
#print(data)#index  表示索引,values表示所要进行分析的数据, columns允许选择一个或多个列,以columns作为分组的列
mean_ratings = data.pivot_table(values ='rating', index='title', columns ='gender', aggfunc='mean')ratings_by_title = data.groupby('title').size() #索引active_titles = ratings_by_title.index[ratings_by_title >= 250] #找出其评论大于250 的索引mean_ratings = mean_ratings.loc[active_titles]
#print(mean_ratings[:5])top_female_ratings=mean_ratings.sort_values(by='F',ascending=False)
#print(top_female_ratings)rating_std = data.groupby('title')['rating'].size()
print(rating_std)
rating_std = rating_std.loc[active_titles]
sorted_rating_std=rating_std.sort_values(ascending=False)

这篇关于《利用Python进行数据分析》数据处理——MovieLens 1M数据集的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/314200

相关文章

LangChain转换链:让数据处理更精准

1. 转换链的概念 在开发AI Agent(智能体)时,我们经常需要对输入数据进行预处理,这样可以更好地利用LLM。LangChain提供了一个强大的工具——转换链(TransformChain),它可以帮我们轻松实现这一任务。 转换链(TransformChain)主要是将 给定的数据 按照某个函数进行转换,再将 转换后的结果 输出给LLM。 所以转换链的核心是:根据业务逻辑编写合适的转换函

大语言模型(LLMs)能够进行推理和规划吗?

大语言模型(LLMs),基本上是经过强化训练的 n-gram 模型,它们在网络规模的语言语料库(实际上,可以说是我们文明的知识库)上进行了训练,展现出了一种超乎预期的语言行为,引发了我们的广泛关注。从训练和操作的角度来看,LLMs 可以被认为是一种巨大的、非真实的记忆库,相当于为我们所有人提供了一个外部的系统 1(见图 1)。然而,它们表面上的多功能性让许多研究者好奇,这些模型是否也能在通常需要系

Python 字符串占位

在Python中,可以使用字符串的格式化方法来实现字符串的占位。常见的方法有百分号操作符 % 以及 str.format() 方法 百分号操作符 % name = "张三"age = 20message = "我叫%s,今年%d岁。" % (name, age)print(message) # 我叫张三,今年20岁。 str.format() 方法 name = "张三"age

【服务器运维】MySQL数据存储至数据盘

查看磁盘及分区 [root@MySQL tmp]# fdisk -lDisk /dev/sda: 21.5 GB, 21474836480 bytes255 heads, 63 sectors/track, 2610 cylindersUnits = cylinders of 16065 * 512 = 8225280 bytesSector size (logical/physical)

一道经典Python程序样例带你飞速掌握Python的字典和列表

Python中的列表(list)和字典(dict)是两种常用的数据结构,它们在数据组织和存储方面有很大的不同。 列表(List) 列表是Python中的一种有序集合,可以随时添加和删除其中的元素。列表中的元素可以是任何数据类型,包括数字、字符串、其他列表等。列表使用方括号[]表示,元素之间用逗号,分隔。 定义和使用 # 定义一个列表 fruits = ['apple', 'banana

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa

SQL Server中,查询数据库中有多少个表,以及数据库其余类型数据统计查询

sqlserver查询数据库中有多少个表 sql server 数表:select count(1) from sysobjects where xtype='U'数视图:select count(1) from sysobjects where xtype='V'数存储过程select count(1) from sysobjects where xtype='P' SE

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

python 喷泉码

因为要完成毕业设计,毕业设计做的是数据分发与传输的东西。在网络中数据容易丢失,所以我用fountain code做所发送数据包的数据恢复。fountain code属于有限域编码的一部分,有很广泛的应用。 我们日常生活中使用的二维码,就用到foutain code做数据恢复。你遮住二维码的四分之一,用手机的相机也照样能识别。你遮住的四分之一就相当于丢失的数据包。 为了实现并理解foutain

python 点滴学

1 python 里面tuple是无法改变的 tuple = (1,),计算tuple里面只有一个元素,也要加上逗号 2  1 毕业论文改 2 leetcode第一题做出来