(計算網(wǎng)站已改版辅愿,本教程已失效)Fe-Ti oxide geothermobarometer (鈦鐵氧化物溫度計) 批量計算溫度和氧逸度

一抡柿、鈦鐵氧化物溫度計

鈦鐵氧化物溫度計(Fe-Ti oxide geothermobarometer )通過計算平衡共生礦物的共有成份分配函數(shù),可以測定礦物大致的結(jié)晶溫度嘲驾。

二、計算軟件

目前比較成熟的計算軟件是由Ghiorso MS , Evans BW (2008)編寫的軟件,提供了Mac Os和Windows平臺的應(yīng)用以及網(wǎng)頁在線版畅卓。
1.Mac Os 版 該版本所兼容的系統(tǒng)(OS 10.5 (Leopard) and OS10.6 (Snow Leopard) 版本早已過時。
2.Windows版 該版本為Excel編寫的宏蟋恬,僅支持Office 2003翁潘,現(xiàn)在誰還用這古老的版本!<哒拜马!
3.網(wǎng)頁在線版 該網(wǎng)頁僅支持手動輸入數(shù)據(jù),且無法完成批量計算沐绒。

那么怎么去實現(xiàn)批量計算呢俩莽?

三、思路解析

首先對excel宏源碼進(jìn)行了分析洒沦,試圖從源代碼里面找到計算公式豹绪,可是大佬寫的VBA代碼里面根本沒有計算公式,而是將excel數(shù)據(jù)以數(shù)組的形式傳遞給了在線服務(wù)器。放棄B鹘颉2跻隆!
既然無法獲取算法公式巷蚪,那么只能打網(wǎng)頁在線版的主意了病毡。

F6A2BE3E-B3AB-49FC-820B-C0B10B778EBD.png

網(wǎng)頁版的界面上可以直接手動輸入數(shù)據(jù)進(jìn)行計算,并返回單次計算結(jié)果屁柏,可是對于批量計算無能為力啦膜。
于是想到的就是用爬蟲批量傳遞數(shù)據(jù)給服務(wù)器,然后爬取返回的結(jié)果寫入excel淌喻。通過分析該網(wǎng)頁網(wǎng)址傳遞參數(shù)到服務(wù)器計算的過程僧家,發(fā)現(xiàn)該網(wǎng)站參數(shù)傳遞非常簡單,僅僅是參數(shù)拼接裸删。參數(shù)傳遞鏈接如下:
http://melts.ofm-research.org/CORBA_CTserver/OxideGeothrm/OxideGeothrmResult.php?SiO2sp=0.0&SiO2rh=0.0&TiO2sp=4.35&TiO2rh=28.73&Al2O3sp=1.94&Al2O3rh=0.35&Fe2O3sp=0.0&Fe2O3rh=0.0&V2O3sp=0.0&V2O3rh=0.0&Cr2O3sp=0.18&Cr2O3rh=0.0&FeOsp=86.34&FeOrh=65.98&MnOsp=0.44&MnOrh=0.23&MgOsp=1.2&MgOrh=1.02&CaOsp=0.0&CaOrh=0.0&ZnOsp=0.0&ZnOrh=0.0&NiOsp=0.0&NiOrh=0.0&Submit1=Calculate+T+and+fO2
所以只需將數(shù)據(jù)按照以上網(wǎng)址的樣式進(jìn)行簡單的組合八拱,即可利用爬蟲實現(xiàn)批量計算。

四涯塔、數(shù)據(jù)準(zhǔn)備

按如下形式整理數(shù)據(jù)為excel肌稻。


7DD9C4923C051145142B42EE9FD02EAF.png

1.表頭分別為兩種礦物的各元素標(biāo)識。\color{red} {表頭順序可更改匕荸,內(nèi)容不能改變爹谭,代碼里已經(jīng)寫死,如改變榛搔,會報錯}诺凡。
2.第一列為每一個測點的編號。

五药薯、實現(xiàn)過程

# -*- coding: utf-8 -*-
"""
Copyright (C) 2021, Inc. All Rights Reserved 
@Time    :2021/9/23 23:18
@Wechart :Pandas120
@Email   :137243562@qq.com
@File    :feti_geothermal.py
@Version :1.1
"""
import requests as rq
from lxml import etree
import pandas as pd
import easygui

###定義一個函數(shù)绑洛,并返回計算結(jié)果
def getresult(data):
    SiO2sp = data["aSiO2"]
    SiO2rh = data["bSiO2"]
    TiO2sp = data["aTiO2"]
    TiO2rh = data["bTiO2"]
    Al2O3sp = data["aAl2O3"]
    Al2O3rh = data["bAl2O3"]
    Fe2O3sp = data["aFe2O3"]
    Fe2O3rh = data["bFe2O3"]
    V2O3sp = data["aV2O3"]
    V2O3rh = data["bV2O3"]
    Cr2O3sp = data["aCr2O3"]
    Cr2O3rh = data["bCr2O3"]
    FeOsp = data["aFeO"]
    FeOrh = data["bFeO"]
    MnOsp = data["aMnO"]
    MnOrh = data["bMnO"]
    MgOsp = data["aMgO"]
    MgOrh = data["bMgO"]
    CaOsp = data["aCaO"]
    CaOrh = data["bCaO"]
    ZnOsp = data["aZnO"]
    ZnOrh = data["bZnO"]
    NiOsp = data["aNiO"]
    NiOrh = data["bNiO"]
    url = f"http://melts.ofm-research.org/CORBA_CTserver/OxideGeothrm/OxideGeothrmResult.php?SiO2sp={SiO2sp}&SiO2rh={SiO2rh}&TiO2sp={TiO2sp}&TiO2rh={TiO2rh}&Al2O3sp={Al2O3sp}&Al2O3rh={Al2O3rh}&Fe2O3sp={Fe2O3sp}&Fe2O3rh={Fe2O3rh}&V2O3sp={V2O3sp}&V2O3rh={V2O3rh}&Cr2O3sp={Cr2O3sp}&Cr2O3rh={Cr2O3rh}&FeOsp={FeOsp}&FeOrh={FeOrh}&MnOsp={MnOsp}&MnOrh={MnOrh}&MgOsp={MgOsp}&MgOrh={MgOrh}&CaOsp={CaOsp}&CaOrh={CaOrh}&ZnOsp={ZnOsp}&ZnOrh={ZnOrh}&NiOsp={NiOsp}&NiOrh={NiOrh}&Submit1=Calculate+T+and+fO2"
    while True:
        res = rq.get(url)
        if res.status_code == 200:
            html = etree.HTML(res.text)
            tfeti = float(html.xpath("/html/body/div/div/div/table[2]/tr[1]/td[2]/div/text()")[0])
            log10f02 = float(html.xpath("/html/body/div/div/div/table[2]/tr[2]/td[2]/div/text()")[0])
            tfemg = float(html.xpath("/html/body/div/div/div/table[2]/tr[3]/td[2]/div/text()")[0])
            ati02 = float(html.xpath("/html/body/div/div/div/table[2]/tr[4]/td[2]/div/text()")[0])
            return tfeti, log10f02, tfemg, ati02
        else:
            print("連接失敗童本!正在重試U嫱汀!")

###主函數(shù)入口
if __name__ == "__main__":
    file = easygui.fileopenbox(filetypes=["*.xls", "*.xlsx"], default="*.xlsx")
    data = pd.read_excel(file, sheet_name=0)
    tfetilist = []
    log10f02list = []
    tfemglist = []
    ati02list = []
    for i in range(data.shape[0]):
        tfeti, log10f02, tfemg, ati02=getresult(data.loc[i, :])
        tfetilist.append(tfeti)
        log10f02list.append(log10f02)
        tfemglist.append(tfemg)
        ati02list.append(ati02)
    data["tfeti"] = tfetilist
    data["log10f02"] = log10f02list
    data["tfemg"] = tfemglist
    data["ati02"] = ati02list
    data.to_excel("result.xlsx",sheet_name="res",index=False)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末穷娱,一起剝皮案震驚了整個濱河市绑蔫,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌泵额,老刑警劉巖配深,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異嫁盲,居然都是意外死亡篓叶,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來缸托,“玉大人左敌,你說我怎么就攤上這事±洌” “怎么了矫限?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長佩抹。 經(jīng)常有香客問我叼风,道長,這世上最難降的妖魔是什么棍苹? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任无宿,我火速辦了婚禮,結(jié)果婚禮上枢里,老公的妹妹穿的比我還像新娘懈贺。我一直安慰自己,他們只是感情好坡垫,可當(dāng)我...
    茶點故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著画侣,像睡著了一般冰悠。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上配乱,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天溉卓,我揣著相機與錄音,去河邊找鬼搬泥。 笑死桑寨,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的忿檩。 我是一名探鬼主播尉尾,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼燥透!你這毒婦竟也來了沙咏?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤班套,失蹤者是張志新(化名)和其女友劉穎肢藐,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體吱韭,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡吆豹,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片痘煤。...
    茶點故事閱讀 39,991評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡凑阶,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出速勇,到底是詐尸還是另有隱情晌砾,我是刑警寧澤,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布烦磁,位于F島的核電站养匈,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏都伪。R本人自食惡果不足惜呕乎,卻給世界環(huán)境...
    茶點故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望陨晶。 院中可真熱鬧猬仁,春花似錦、人聲如沸先誉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽褐耳。三九已至诈闺,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間铃芦,已是汗流浹背雅镊。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留刃滓,地道東北人仁烹。 一個月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像咧虎,于是被迫代替她去往敵國和親卓缰。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,941評論 2 355

推薦閱讀更多精彩內(nèi)容